diff --git a/config.codekit b/config.codekit new file mode 100644 index 00000000..91f07c6f --- /dev/null +++ b/config.codekit @@ -0,0 +1,6844 @@ +{ +"CodeKitInfo": "This is a CodeKit 2.x project configuration file. It is designed to sync project settings across multiple machines. MODIFYING THE CONTENTS OF THIS FILE IS A POOR LIFE DECISION. If you do so, you will likely cause CodeKit to crash. This file is not useful unless accompanied by the project that created it in CodeKit 2. This file is not backwards-compatible with CodeKit 1.x. For more information, see: http:\/\/incident57.com\/codekit", +"creatorBuild": "19033", +"files": { + "\/404.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/404.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/archive-custom_type.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/archive-custom_type.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/archive.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/archive.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/author-info.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/author-info.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/breadcrumb.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/breadcrumb.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/comments.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/comments.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/footer.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/footer.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/functions.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/functions.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/header.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/header.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/index.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/index.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/bootstrap_tests.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/bootstrap_tests.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/CHANGELOG.md": { + "criticStyle": 0, + "enableFootnotes": 1, + "enableLabels": 1, + "enableSmartQuotes": 1, + "escapeLineBreaks": 0, + "fileType": 4096, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/CHANGELOG.md", + "maskEmailAddresses": 1, + "outputAbbreviatedPath": "\/library\/admin\/CHANGELOG.html", + "outputFormat": 0, + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "parseMetadata": 1, + "processHTML": 0, + "randomFootnoteNumbers": 0, + "useCompatibilityMode": 0 + }, + "\/library\/admin\/class.redux-plugin.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/class.redux-plugin.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/codestyles\/README.md": { + "criticStyle": 0, + "enableFootnotes": 1, + "enableLabels": 1, + "enableSmartQuotes": 1, + "escapeLineBreaks": 0, + "fileType": 4096, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/codestyles\/README.md", + "maskEmailAddresses": 1, + "outputAbbreviatedPath": "\/library\/admin\/codestyles\/README.html", + "outputFormat": 0, + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "parseMetadata": 1, + "processHTML": 0, + "randomFootnoteNumbers": 0, + "useCompatibilityMode": 0 + }, + "\/library\/admin\/composer.json": { + "fileType": 524288, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/composer.json", + "orderOutput": 0, + "outputAbbreviatedPath": "\/library\/admin\/composer-min.json", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1 + }, + "\/library\/admin\/CONTRIBUTING.md": { + "criticStyle": 0, + "enableFootnotes": 1, + "enableLabels": 1, + "enableSmartQuotes": 1, + "escapeLineBreaks": 0, + "fileType": 4096, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/CONTRIBUTING.md", + "maskEmailAddresses": 1, + "outputAbbreviatedPath": "\/library\/admin\/CONTRIBUTING.html", + "outputFormat": 0, + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "parseMetadata": 1, + "processHTML": 0, + "randomFootnoteNumbers": 0, + "useCompatibilityMode": 0 + }, + "\/library\/admin\/Gruntfile.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/Gruntfile.js", + "outputAbbreviatedPath": "\/library\/admin\/min\/Gruntfile-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/index.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/index.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/package.json": { + "fileType": 524288, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/package.json", + "orderOutput": 0, + "outputAbbreviatedPath": "\/library\/admin\/package-min.json", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1 + }, + "\/library\/admin\/README.md": { + "criticStyle": 0, + "enableFootnotes": 1, + "enableLabels": 1, + "enableSmartQuotes": 1, + "escapeLineBreaks": 0, + "fileType": 4096, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/README.md", + "maskEmailAddresses": 1, + "outputAbbreviatedPath": "\/library\/admin\/README.html", + "outputFormat": 0, + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "parseMetadata": 1, + "processHTML": 0, + "randomFootnoteNumbers": 0, + "useCompatibilityMode": 0 + }, + "\/library\/admin\/redux-framework.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/redux-framework.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/assets\/css\/color-picker\/color-picker.css": { + "fileType": 16, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/color-picker\/color-picker.css", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/assets\/css\/color-picker\/color-picker.scss": { + "createSourceMap": 0, + "debugStyle": 0, + "decimalPrecision": 10, + "fileType": 4, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/color-picker\/color-picker.scss", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/css\/color-picker.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "useLibsass": 0 + }, + "\/library\/admin\/ReduxCore\/assets\/css\/import_export\/import_export.css": { + "fileType": 16, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/import_export\/import_export.css", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/assets\/css\/media\/media.css": { + "fileType": 16, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/media\/media.css", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/assets\/css\/media\/media.scss": { + "createSourceMap": 0, + "debugStyle": 0, + "decimalPrecision": 10, + "fileType": 4, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/media\/media.scss", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/css\/media.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "useLibsass": 0 + }, + "\/library\/admin\/ReduxCore\/assets\/css\/redux-admin.css": { + "fileType": 16, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/redux-admin.css", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/assets\/css\/redux-admin.scss": { + "createSourceMap": 0, + "debugStyle": 0, + "decimalPrecision": 10, + "fileType": 4, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/redux-admin.scss", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/redux-admin.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "useLibsass": 0 + }, + "\/library\/admin\/ReduxCore\/assets\/css\/redux-fields.css": { + "fileType": 16, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/redux-fields.css", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/assets\/css\/redux-vendor.css": { + "fileType": 16, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/redux-vendor.css", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/assets\/css\/rtl.css": { + "fileType": 16, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/rtl.css", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/assets\/css\/rtl.scss": { + "createSourceMap": 0, + "debugStyle": 0, + "decimalPrecision": 10, + "fileType": 4, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/rtl.scss", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/rtl.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "useLibsass": 0 + }, + "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/elusive-icons\/elusive-icons.css": { + "fileType": 16, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/elusive-icons\/elusive-icons.css", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/elusive-icons\/scss\/_animated.scss": { + "createSourceMap": 0, + "debugStyle": 0, + "decimalPrecision": 10, + "fileType": 4, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/elusive-icons\/scss\/_animated.scss", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/elusive-icons\/css\/_animated.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "useLibsass": 0 + }, + "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/elusive-icons\/scss\/_bordered-pulled.scss": { + "createSourceMap": 0, + "debugStyle": 0, + "decimalPrecision": 10, + "fileType": 4, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/elusive-icons\/scss\/_bordered-pulled.scss", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/elusive-icons\/css\/_bordered-pulled.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "useLibsass": 0 + }, + "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/elusive-icons\/scss\/_core.scss": { + "createSourceMap": 0, + "debugStyle": 0, + "decimalPrecision": 10, + "fileType": 4, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/elusive-icons\/scss\/_core.scss", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/elusive-icons\/css\/_core.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "useLibsass": 0 + }, + "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/elusive-icons\/scss\/_fixed-width.scss": { + "createSourceMap": 0, + "debugStyle": 0, + "decimalPrecision": 10, + "fileType": 4, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/elusive-icons\/scss\/_fixed-width.scss", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/elusive-icons\/css\/_fixed-width.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "useLibsass": 0 + }, + "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/elusive-icons\/scss\/_icons.scss": { + "createSourceMap": 0, + "debugStyle": 0, + "decimalPrecision": 10, + "fileType": 4, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/elusive-icons\/scss\/_icons.scss", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/elusive-icons\/css\/_icons.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "useLibsass": 0 + }, + "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/elusive-icons\/scss\/_larger.scss": { + "createSourceMap": 0, + "debugStyle": 0, + "decimalPrecision": 10, + "fileType": 4, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/elusive-icons\/scss\/_larger.scss", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/elusive-icons\/css\/_larger.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "useLibsass": 0 + }, + "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/elusive-icons\/scss\/_list.scss": { + "createSourceMap": 0, + "debugStyle": 0, + "decimalPrecision": 10, + "fileType": 4, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/elusive-icons\/scss\/_list.scss", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/elusive-icons\/css\/_list.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "useLibsass": 0 + }, + "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/elusive-icons\/scss\/_mixins.scss": { + "createSourceMap": 0, + "debugStyle": 0, + "decimalPrecision": 10, + "fileType": 4, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/elusive-icons\/scss\/_mixins.scss", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/elusive-icons\/css\/_mixins.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "useLibsass": 0 + }, + "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/elusive-icons\/scss\/_path.scss": { + "createSourceMap": 0, + "debugStyle": 0, + "decimalPrecision": 10, + "fileType": 4, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/elusive-icons\/scss\/_path.scss", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/elusive-icons\/css\/_path.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "useLibsass": 0 + }, + "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/elusive-icons\/scss\/_rotated-flipped.scss": { + "createSourceMap": 0, + "debugStyle": 0, + "decimalPrecision": 10, + "fileType": 4, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/elusive-icons\/scss\/_rotated-flipped.scss", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/elusive-icons\/css\/_rotated-flipped.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "useLibsass": 0 + }, + "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/elusive-icons\/scss\/_stacked.scss": { + "createSourceMap": 0, + "debugStyle": 0, + "decimalPrecision": 10, + "fileType": 4, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/elusive-icons\/scss\/_stacked.scss", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/elusive-icons\/css\/_stacked.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "useLibsass": 0 + }, + "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/elusive-icons\/scss\/_variables.scss": { + "createSourceMap": 0, + "debugStyle": 0, + "decimalPrecision": 10, + "fileType": 4, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/elusive-icons\/scss\/_variables.scss", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/elusive-icons\/css\/_variables.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "useLibsass": 0 + }, + "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/elusive-icons\/scss\/elusive-icons.css": { + "fileType": 16, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/elusive-icons\/scss\/elusive-icons.css", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/elusive-icons\/scss\/elusive-icons.scss": { + "createSourceMap": 0, + "debugStyle": 0, + "decimalPrecision": 10, + "fileType": 4, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/elusive-icons\/scss\/elusive-icons.scss", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/elusive-icons\/css\/elusive-icons.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "useLibsass": 0 + }, + "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/jquery-ui-bootstrap\/images\/ui-bg_flat_0_aaaaaa_40x100.png": { + "fileType": 32768, + "ignore": 0, + "ignoreWasSetByUser": 0, + "initialSize": 180, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/jquery-ui-bootstrap\/images\/ui-bg_flat_0_aaaaaa_40x100.png", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/jquery-ui-bootstrap\/images\/ui-bg_flat_0_aaaaaa_40x100.png", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "processed": 0 + }, + "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/jquery-ui-bootstrap\/images\/ui-bg_glass_55_fbf9ee_1x400.png": { + "fileType": 32768, + "ignore": 0, + "ignoreWasSetByUser": 0, + "initialSize": 120, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/jquery-ui-bootstrap\/images\/ui-bg_glass_55_fbf9ee_1x400.png", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/jquery-ui-bootstrap\/images\/ui-bg_glass_55_fbf9ee_1x400.png", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "processed": 0 + }, + "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/jquery-ui-bootstrap\/images\/ui-bg_glass_65_ffffff_1x400.png": { + "fileType": 32768, + "ignore": 0, + "ignoreWasSetByUser": 0, + "initialSize": 105, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/jquery-ui-bootstrap\/images\/ui-bg_glass_65_ffffff_1x400.png", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/jquery-ui-bootstrap\/images\/ui-bg_glass_65_ffffff_1x400.png", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "processed": 0 + }, + "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/jquery-ui-bootstrap\/images\/ui-bg_glass_75_dadada_1x400.png": { + "fileType": 32768, + "ignore": 0, + "ignoreWasSetByUser": 0, + "initialSize": 111, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/jquery-ui-bootstrap\/images\/ui-bg_glass_75_dadada_1x400.png", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/jquery-ui-bootstrap\/images\/ui-bg_glass_75_dadada_1x400.png", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "processed": 0 + }, + "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/jquery-ui-bootstrap\/images\/ui-bg_glass_75_e6e6e6_1x400.png": { + "fileType": 32768, + "ignore": 0, + "ignoreWasSetByUser": 0, + "initialSize": 110, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/jquery-ui-bootstrap\/images\/ui-bg_glass_75_e6e6e6_1x400.png", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/jquery-ui-bootstrap\/images\/ui-bg_glass_75_e6e6e6_1x400.png", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "processed": 0 + }, + "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/jquery-ui-bootstrap\/images\/ui-bg_glass_75_ffffff_1x400.png": { + "fileType": 32768, + "ignore": 0, + "ignoreWasSetByUser": 0, + "initialSize": 107, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/jquery-ui-bootstrap\/images\/ui-bg_glass_75_ffffff_1x400.png", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/jquery-ui-bootstrap\/images\/ui-bg_glass_75_ffffff_1x400.png", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "processed": 0 + }, + "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/jquery-ui-bootstrap\/images\/ui-bg_highlight-soft_75_cccccc_1x100.png": { + "fileType": 32768, + "ignore": 0, + "ignoreWasSetByUser": 0, + "initialSize": 101, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/jquery-ui-bootstrap\/images\/ui-bg_highlight-soft_75_cccccc_1x100.png", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/jquery-ui-bootstrap\/images\/ui-bg_highlight-soft_75_cccccc_1x100.png", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "processed": 0 + }, + "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/jquery-ui-bootstrap\/images\/ui-bg_inset-soft_95_fef1ec_1x100.png": { + "fileType": 32768, + "ignore": 0, + "ignoreWasSetByUser": 0, + "initialSize": 123, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/jquery-ui-bootstrap\/images\/ui-bg_inset-soft_95_fef1ec_1x100.png", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/jquery-ui-bootstrap\/images\/ui-bg_inset-soft_95_fef1ec_1x100.png", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "processed": 0 + }, + "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/jquery-ui-bootstrap\/images\/ui-icons_222222_256x240.png": { + "fileType": 32768, + "ignore": 0, + "ignoreWasSetByUser": 0, + "initialSize": 4369, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/jquery-ui-bootstrap\/images\/ui-icons_222222_256x240.png", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/jquery-ui-bootstrap\/images\/ui-icons_222222_256x240.png", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "processed": 0 + }, + "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/jquery-ui-bootstrap\/images\/ui-icons_2e83ff_256x240.png": { + "fileType": 32768, + "ignore": 0, + "ignoreWasSetByUser": 0, + "initialSize": 4369, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/jquery-ui-bootstrap\/images\/ui-icons_2e83ff_256x240.png", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/jquery-ui-bootstrap\/images\/ui-icons_2e83ff_256x240.png", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "processed": 0 + }, + "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/jquery-ui-bootstrap\/images\/ui-icons_454545_256x240.png": { + "fileType": 32768, + "ignore": 0, + "ignoreWasSetByUser": 0, + "initialSize": 4369, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/jquery-ui-bootstrap\/images\/ui-icons_454545_256x240.png", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/jquery-ui-bootstrap\/images\/ui-icons_454545_256x240.png", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "processed": 0 + }, + "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/jquery-ui-bootstrap\/images\/ui-icons_888888_256x240.png": { + "fileType": 32768, + "ignore": 0, + "ignoreWasSetByUser": 0, + "initialSize": 4369, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/jquery-ui-bootstrap\/images\/ui-icons_888888_256x240.png", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/jquery-ui-bootstrap\/images\/ui-icons_888888_256x240.png", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "processed": 0 + }, + "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/jquery-ui-bootstrap\/images\/ui-icons_cd0a0a_256x240.png": { + "fileType": 32768, + "ignore": 0, + "ignoreWasSetByUser": 0, + "initialSize": 4369, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/jquery-ui-bootstrap\/images\/ui-icons_cd0a0a_256x240.png", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/jquery-ui-bootstrap\/images\/ui-icons_cd0a0a_256x240.png", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "processed": 0 + }, + "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/jquery-ui-bootstrap\/images\/ui-icons_f6cf3b_256x240.png": { + "fileType": 32768, + "ignore": 0, + "ignoreWasSetByUser": 0, + "initialSize": 8884, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/jquery-ui-bootstrap\/images\/ui-icons_f6cf3b_256x240.png", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/jquery-ui-bootstrap\/images\/ui-icons_f6cf3b_256x240.png", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "processed": 0 + }, + "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/jquery-ui-bootstrap\/images\/ui-icons_ffffff_256x240.png": { + "fileType": 32768, + "ignore": 0, + "ignoreWasSetByUser": 0, + "initialSize": 4369, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/jquery-ui-bootstrap\/images\/ui-icons_ffffff_256x240.png", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/jquery-ui-bootstrap\/images\/ui-icons_ffffff_256x240.png", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "processed": 0 + }, + "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/jquery-ui-bootstrap\/jquery-ui-1.10.0.custom.css": { + "fileType": 16, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/jquery-ui-bootstrap\/jquery-ui-1.10.0.custom.css", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/jquery-ui-bootstrap\/jquery-ui-1.10.0.custom.less": { + "allowInsecureImports": 0, + "createSourceMap": 0, + "disableJavascript": 0, + "fileType": 1, + "ieCompatibility": 1, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/jquery-ui-bootstrap\/jquery-ui-1.10.0.custom.less", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/css\/jquery-ui-1.10.0.custom.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "relativeURLS": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "strictImports": 0, + "strictMath": 0, + "strictUnits": 0 + }, + "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/jquery-ui-bootstrap\/jquery-ui-1.10.0.custom.scss": { + "createSourceMap": 0, + "debugStyle": 0, + "decimalPrecision": 10, + "fileType": 4, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/jquery-ui-bootstrap\/jquery-ui-1.10.0.custom.scss", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/css\/jquery-ui-1.10.0.custom.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "useLibsass": 0 + }, + "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/qtip\/jquery.qtip.css": { + "fileType": 16, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/qtip\/jquery.qtip.css", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/qtip\/jquery.qtip.min.css": { + "fileType": 16, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/qtip\/jquery.qtip.min.css", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/spectrum\/redux-spectrum.css": { + "fileType": 16, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/spectrum\/redux-spectrum.css", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/spectrum\/redux-spectrum.min.css": { + "fileType": 16, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/css\/vendor\/spectrum\/redux-spectrum.min.css", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/assets\/img\/1c.png": { + "fileType": 32768, + "ignore": 0, + "ignoreWasSetByUser": 0, + "initialSize": 138, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/img\/1c.png", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/img\/1c.png", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "processed": 0 + }, + "\/library\/admin\/ReduxCore\/assets\/img\/1col.png": { + "fileType": 32768, + "ignore": 0, + "ignoreWasSetByUser": 0, + "initialSize": 2895, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/img\/1col.png", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/img\/1col.png", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "processed": 0 + }, + "\/library\/admin\/ReduxCore\/assets\/img\/2-col-portfolio.png": { + "fileType": 32768, + "ignore": 0, + "ignoreWasSetByUser": 0, + "initialSize": 1045, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/img\/2-col-portfolio.png", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/img\/2-col-portfolio.png", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "processed": 0 + }, + "\/library\/admin\/ReduxCore\/assets\/img\/2cl.png": { + "fileType": 32768, + "ignore": 0, + "ignoreWasSetByUser": 0, + "initialSize": 2984, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/img\/2cl.png", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/img\/2cl.png", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "processed": 0 + }, + "\/library\/admin\/ReduxCore\/assets\/img\/2cr.png": { + "fileType": 32768, + "ignore": 0, + "ignoreWasSetByUser": 0, + "initialSize": 2985, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/img\/2cr.png", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/img\/2cr.png", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "processed": 0 + }, + "\/library\/admin\/ReduxCore\/assets\/img\/3-col-portfolio.png": { + "fileType": 32768, + "ignore": 0, + "ignoreWasSetByUser": 0, + "initialSize": 1025, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/img\/3-col-portfolio.png", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/img\/3-col-portfolio.png", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "processed": 0 + }, + "\/library\/admin\/ReduxCore\/assets\/img\/3cl.png": { + "fileType": 32768, + "ignore": 0, + "ignoreWasSetByUser": 0, + "initialSize": 3156, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/img\/3cl.png", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/img\/3cl.png", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "processed": 0 + }, + "\/library\/admin\/ReduxCore\/assets\/img\/3cm.png": { + "fileType": 32768, + "ignore": 0, + "ignoreWasSetByUser": 0, + "initialSize": 3036, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/img\/3cm.png", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/img\/3cm.png", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "processed": 0 + }, + "\/library\/admin\/ReduxCore\/assets\/img\/3cr.png": { + "fileType": 32768, + "ignore": 0, + "ignoreWasSetByUser": 0, + "initialSize": 3050, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/img\/3cr.png", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/img\/3cr.png", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "processed": 0 + }, + "\/library\/admin\/ReduxCore\/assets\/img\/4-col-portfolio.png": { + "fileType": 32768, + "ignore": 0, + "ignoreWasSetByUser": 0, + "initialSize": 1033, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/img\/4-col-portfolio.png", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/img\/4-col-portfolio.png", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "processed": 0 + }, + "\/library\/admin\/ReduxCore\/assets\/img\/menu_icon.png": { + "fileType": 32768, + "ignore": 0, + "ignoreWasSetByUser": 0, + "initialSize": 1447, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/img\/menu_icon.png", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/img\/menu_icon.png", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "processed": 0 + }, + "\/library\/admin\/ReduxCore\/assets\/img\/toggle_tabs.png": { + "fileType": 32768, + "ignore": 0, + "ignoreWasSetByUser": 0, + "initialSize": 358, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/img\/toggle_tabs.png", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/img\/toggle_tabs.png", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "processed": 0 + }, + "\/library\/admin\/ReduxCore\/assets\/js\/media\/media.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/js\/media\/media.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/js\/media\/min\/media-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/assets\/js\/media\/media.min.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/js\/media\/media.min.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/js\/media\/min\/media.min-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/assets\/js\/redux.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/js\/redux.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/js\/min\/redux-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/assets\/js\/redux.min.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/js\/redux.min.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/js\/min\/redux.min-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/assets\/js\/vendor.min.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/js\/vendor.min.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/js\/min\/vendor.min-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/assets\/js\/vendor\/cookie.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/js\/vendor\/cookie.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/js\/vendor\/min\/cookie-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/assets\/js\/vendor\/jquery.alphanum.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/js\/vendor\/jquery.alphanum.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/js\/vendor\/min\/jquery.alphanum-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/assets\/js\/vendor\/jquery.serializeForm.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/js\/vendor\/jquery.serializeForm.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/js\/vendor\/min\/jquery.serializeForm-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/assets\/js\/vendor\/jquery.typewatch.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/js\/vendor\/jquery.typewatch.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/js\/vendor\/min\/jquery.typewatch-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/assets\/js\/vendor\/jsonview.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/js\/vendor\/jsonview.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/js\/vendor\/min\/jsonview-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/assets\/js\/vendor\/jsonview.min.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/js\/vendor\/jsonview.min.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/js\/vendor\/min\/jsonview.min-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/assets\/js\/vendor\/lte-ie7.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/js\/vendor\/lte-ie7.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/js\/vendor\/min\/lte-ie7-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/assets\/js\/vendor\/qtip\/jquery.qtip.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/js\/vendor\/qtip\/jquery.qtip.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/js\/vendor\/qtip\/min\/jquery.qtip-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/assets\/js\/vendor\/qtip\/jquery.qtip.min.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/js\/vendor\/qtip\/jquery.qtip.min.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/js\/vendor\/qtip\/min\/jquery.qtip.min-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/assets\/js\/vendor\/redux.select2.sortable.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/js\/vendor\/redux.select2.sortable.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/js\/vendor\/min\/redux.select2.sortable-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/assets\/js\/vendor\/redux.select2.sortable.min.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/js\/vendor\/redux.select2.sortable.min.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/js\/vendor\/min\/redux.select2.sortable.min-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/assets\/js\/vendor\/spectrum\/redux-spectrum.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/js\/vendor\/spectrum\/redux-spectrum.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/js\/vendor\/spectrum\/min\/redux-spectrum-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/assets\/js\/vendor\/spectrum\/redux-spectrum.min.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/js\/vendor\/spectrum\/redux-spectrum.min.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/assets\/js\/vendor\/spectrum\/min\/redux-spectrum.min-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/core\/dashboard.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/core\/dashboard.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/core\/enqueue.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/core\/enqueue.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/core\/newsflash.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/core\/newsflash.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/core\/panel.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/core\/panel.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/core\/required.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/core\/required.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/framework.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/framework.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/browser.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/browser.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/class.p.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/class.p.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/class.redux_admin_notices.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/class.redux_admin_notices.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/class.redux_api.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/class.redux_api.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/class.redux_cdn.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/class.redux_cdn.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/class.redux_filesystem.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/class.redux_filesystem.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/class.redux_functions.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/class.redux_functions.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/class.redux_helpers.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/class.redux_helpers.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/class.redux_instances.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/class.redux_instances.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/extensions\/customizer\/extension_customizer.css": { + "fileType": 16, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/extensions\/customizer\/extension_customizer.css", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/extensions\/customizer\/extension_customizer.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/extensions\/customizer\/extension_customizer.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/extensions\/customizer\/min\/extension_customizer-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/inc\/extensions\/customizer\/extension_customizer.min.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/extensions\/customizer\/extension_customizer.min.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/extensions\/customizer\/min\/extension_customizer.min-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/inc\/extensions\/customizer\/extension_customizer.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/extensions\/customizer\/extension_customizer.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/extensions\/customizer\/extension_customizer.scss": { + "createSourceMap": 0, + "debugStyle": 0, + "decimalPrecision": 10, + "fileType": 4, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/extensions\/customizer\/extension_customizer.scss", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/extensions\/css\/extension_customizer.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "useLibsass": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/extensions\/customizer\/inc\/customizer_control.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/extensions\/customizer\/inc\/customizer_control.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/extensions\/customizer\/inc\/customizer_devs.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/extensions\/customizer\/inc\/customizer_devs.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/extensions\/customizer\/inc\/customizer_fields.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/extensions\/customizer\/inc\/customizer_fields.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/extensions\/customizer\/inc\/customizer_panel.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/extensions\/customizer\/inc\/customizer_panel.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/extensions\/customizer\/inc\/customizer_section.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/extensions\/customizer\/inc\/customizer_section.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/extensions\/import_export\/extension_import_export.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/extensions\/import_export\/extension_import_export.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/extensions\/import_export\/import_export\/field_import_export.css": { + "fileType": 16, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/extensions\/import_export\/import_export\/field_import_export.css", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/extensions\/import_export\/import_export\/field_import_export.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/extensions\/import_export\/import_export\/field_import_export.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/extensions\/import_export\/import_export\/min\/field_import_export-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/inc\/extensions\/import_export\/import_export\/field_import_export.min.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/extensions\/import_export\/import_export\/field_import_export.min.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/extensions\/import_export\/import_export\/min\/field_import_export.min-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/inc\/extensions\/import_export\/import_export\/field_import_export.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/extensions\/import_export\/import_export\/field_import_export.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/extensions\/import_export\/import_export\/field_import_export.scss": { + "createSourceMap": 0, + "debugStyle": 0, + "decimalPrecision": 10, + "fileType": 4, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/extensions\/import_export\/import_export\/field_import_export.scss", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/extensions\/import_export\/css\/field_import_export.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "useLibsass": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/extensions\/options_object\/extension_options_object.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/extensions\/options_object\/extension_options_object.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/extensions\/options_object\/options_object\/field_options_object.css": { + "fileType": 16, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/extensions\/options_object\/options_object\/field_options_object.css", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/extensions\/options_object\/options_object\/field_options_object.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/extensions\/options_object\/options_object\/field_options_object.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/extensions\/options_object\/options_object\/min\/field_options_object-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/inc\/extensions\/options_object\/options_object\/field_options_object.min.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/extensions\/options_object\/options_object\/field_options_object.min.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/extensions\/options_object\/options_object\/min\/field_options_object.min-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/inc\/extensions\/options_object\/options_object\/field_options_object.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/extensions\/options_object\/options_object\/field_options_object.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/extensions\/options_object\/options_object\/field_options_object.scss": { + "createSourceMap": 0, + "debugStyle": 0, + "decimalPrecision": 10, + "fileType": 4, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/extensions\/options_object\/options_object\/field_options_object.scss", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/extensions\/options_object\/css\/field_options_object.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "useLibsass": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/ace_editor\/field_ace_editor.css": { + "fileType": 16, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/ace_editor\/field_ace_editor.css", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/ace_editor\/field_ace_editor.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/ace_editor\/field_ace_editor.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/ace_editor\/min\/field_ace_editor-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/ace_editor\/field_ace_editor.min.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/ace_editor\/field_ace_editor.min.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/ace_editor\/min\/field_ace_editor.min-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/ace_editor\/field_ace_editor.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/ace_editor\/field_ace_editor.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/ace_editor\/field_ace_editor.scss": { + "createSourceMap": 0, + "debugStyle": 0, + "decimalPrecision": 10, + "fileType": 4, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/ace_editor\/field_ace_editor.scss", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/css\/field_ace_editor.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "useLibsass": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/background\/field_background.css": { + "fileType": 16, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/background\/field_background.css", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/background\/field_background.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/background\/field_background.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/background\/min\/field_background-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/background\/field_background.min.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/background\/field_background.min.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/background\/min\/field_background.min-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/background\/field_background.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/background\/field_background.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/background\/field_background.scss": { + "createSourceMap": 0, + "debugStyle": 0, + "decimalPrecision": 10, + "fileType": 4, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/background\/field_background.scss", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/css\/field_background.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "useLibsass": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/border\/field_border.css": { + "fileType": 16, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/border\/field_border.css", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/border\/field_border.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/border\/field_border.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/border\/min\/field_border-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/border\/field_border.min.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/border\/field_border.min.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/border\/min\/field_border.min-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/border\/field_border.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/border\/field_border.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/border\/field_border.scss": { + "createSourceMap": 0, + "debugStyle": 0, + "decimalPrecision": 10, + "fileType": 4, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/border\/field_border.scss", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/css\/field_border.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "useLibsass": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/button_set\/field_button_set.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/button_set\/field_button_set.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/button_set\/min\/field_button_set-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/button_set\/field_button_set.min.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/button_set\/field_button_set.min.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/button_set\/min\/field_button_set.min-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/button_set\/field_button_set.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/button_set\/field_button_set.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/checkbox\/field_checkbox.css": { + "fileType": 16, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/checkbox\/field_checkbox.css", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/checkbox\/field_checkbox.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/checkbox\/field_checkbox.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/checkbox\/min\/field_checkbox-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/checkbox\/field_checkbox.min.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/checkbox\/field_checkbox.min.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/checkbox\/min\/field_checkbox.min-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/checkbox\/field_checkbox.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/checkbox\/field_checkbox.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/checkbox\/field_checkbox.scss": { + "createSourceMap": 0, + "debugStyle": 0, + "decimalPrecision": 10, + "fileType": 4, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/checkbox\/field_checkbox.scss", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/css\/field_checkbox.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "useLibsass": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/color\/field_color.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/color\/field_color.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/color\/min\/field_color-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/color\/field_color.min.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/color\/field_color.min.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/color\/min\/field_color.min-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/color\/field_color.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/color\/field_color.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/color_gradient\/field_color_gradient.css": { + "fileType": 16, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/color_gradient\/field_color_gradient.css", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/color_gradient\/field_color_gradient.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/color_gradient\/field_color_gradient.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/color_gradient\/min\/field_color_gradient-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/color_gradient\/field_color_gradient.min.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/color_gradient\/field_color_gradient.min.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/color_gradient\/min\/field_color_gradient.min-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/color_gradient\/field_color_gradient.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/color_gradient\/field_color_gradient.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/color_gradient\/field_color_gradient.scss": { + "createSourceMap": 0, + "debugStyle": 0, + "decimalPrecision": 10, + "fileType": 4, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/color_gradient\/field_color_gradient.scss", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/css\/field_color_gradient.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "useLibsass": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/color_rgba\/field_color_rgba.css": { + "fileType": 16, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/color_rgba\/field_color_rgba.css", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/color_rgba\/field_color_rgba.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/color_rgba\/field_color_rgba.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/color_rgba\/min\/field_color_rgba-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/color_rgba\/field_color_rgba.min.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/color_rgba\/field_color_rgba.min.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/color_rgba\/min\/field_color_rgba.min-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/color_rgba\/field_color_rgba.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/color_rgba\/field_color_rgba.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/color_rgba\/field_color_rgba.scss": { + "createSourceMap": 0, + "debugStyle": 0, + "decimalPrecision": 10, + "fileType": 4, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/color_rgba\/field_color_rgba.scss", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/css\/field_color_rgba.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "useLibsass": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/date\/field_date.css": { + "fileType": 16, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/date\/field_date.css", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/date\/field_date.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/date\/field_date.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/date\/min\/field_date-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/date\/field_date.min.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/date\/field_date.min.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/date\/min\/field_date.min-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/date\/field_date.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/date\/field_date.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/date\/field_date.scss": { + "createSourceMap": 0, + "debugStyle": 0, + "decimalPrecision": 10, + "fileType": 4, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/date\/field_date.scss", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/css\/field_date.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "useLibsass": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/dimensions\/field_dimensions.css": { + "fileType": 16, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/dimensions\/field_dimensions.css", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/dimensions\/field_dimensions.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/dimensions\/field_dimensions.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/dimensions\/min\/field_dimensions-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/dimensions\/field_dimensions.less": { + "allowInsecureImports": 0, + "createSourceMap": 0, + "disableJavascript": 0, + "fileType": 1, + "ieCompatibility": 1, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/dimensions\/field_dimensions.less", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/css\/field_dimensions.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "relativeURLS": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "strictImports": 0, + "strictMath": 0, + "strictUnits": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/dimensions\/field_dimensions.min.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/dimensions\/field_dimensions.min.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/dimensions\/min\/field_dimensions.min-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/dimensions\/field_dimensions.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/dimensions\/field_dimensions.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/dimensions\/field_dimensions.scss": { + "createSourceMap": 0, + "debugStyle": 0, + "decimalPrecision": 10, + "fileType": 4, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/dimensions\/field_dimensions.scss", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/css\/field_dimensions.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "useLibsass": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/divide\/field_divide.css": { + "fileType": 16, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/divide\/field_divide.css", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/divide\/field_divide.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/divide\/field_divide.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/divide\/field_divide.scss": { + "createSourceMap": 0, + "debugStyle": 0, + "decimalPrecision": 10, + "fileType": 4, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/divide\/field_divide.scss", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/css\/field_divide.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "useLibsass": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/editor\/field_editor.css": { + "fileType": 16, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/editor\/field_editor.css", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/editor\/field_editor.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/editor\/field_editor.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/editor\/min\/field_editor-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/editor\/field_editor.min.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/editor\/field_editor.min.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/editor\/min\/field_editor.min-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/editor\/field_editor.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/editor\/field_editor.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/editor\/field_editor.scss": { + "createSourceMap": 0, + "debugStyle": 0, + "decimalPrecision": 10, + "fileType": 4, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/editor\/field_editor.scss", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/css\/field_editor.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "useLibsass": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/editor\/field_editor_c.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/editor\/field_editor_c.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/gallery\/field_gallery.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/gallery\/field_gallery.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/gallery\/min\/field_gallery-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/gallery\/field_gallery.min.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/gallery\/field_gallery.min.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/gallery\/min\/field_gallery.min-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/gallery\/field_gallery.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/gallery\/field_gallery.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/image_select\/field_image_select.css": { + "fileType": 16, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/image_select\/field_image_select.css", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/image_select\/field_image_select.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/image_select\/field_image_select.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/image_select\/min\/field_image_select-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/image_select\/field_image_select.min.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/image_select\/field_image_select.min.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/image_select\/min\/field_image_select.min-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/image_select\/field_image_select.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/image_select\/field_image_select.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/image_select\/field_image_select.scss": { + "createSourceMap": 0, + "debugStyle": 0, + "decimalPrecision": 10, + "fileType": 4, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/image_select\/field_image_select.scss", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/css\/field_image_select.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "useLibsass": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/info\/field_info.css": { + "fileType": 16, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/info\/field_info.css", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/info\/field_info.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/info\/field_info.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/info\/field_info.scss": { + "createSourceMap": 0, + "debugStyle": 0, + "decimalPrecision": 10, + "fileType": 4, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/info\/field_info.scss", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/css\/field_info.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "useLibsass": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/link_color\/field_link_color.css": { + "fileType": 16, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/link_color\/field_link_color.css", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/link_color\/field_link_color.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/link_color\/field_link_color.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/link_color\/min\/field_link_color-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/link_color\/field_link_color.min.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/link_color\/field_link_color.min.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/link_color\/min\/field_link_color.min-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/link_color\/field_link_color.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/link_color\/field_link_color.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/link_color\/field_link_color.scss": { + "createSourceMap": 0, + "debugStyle": 0, + "decimalPrecision": 10, + "fileType": 4, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/link_color\/field_link_color.scss", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/css\/field_link_color.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "useLibsass": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/media\/field_media.css": { + "fileType": 16, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/media\/field_media.css", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/media\/field_media.less": { + "allowInsecureImports": 0, + "createSourceMap": 0, + "disableJavascript": 0, + "fileType": 1, + "ieCompatibility": 1, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/media\/field_media.less", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/css\/field_media.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "relativeURLS": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "strictImports": 0, + "strictMath": 0, + "strictUnits": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/media\/field_media.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/media\/field_media.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/media\/field_media.scss": { + "createSourceMap": 0, + "debugStyle": 0, + "decimalPrecision": 10, + "fileType": 4, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/media\/field_media.scss", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/css\/field_media.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "useLibsass": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/multi_text\/field_multi_text.css": { + "fileType": 16, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/multi_text\/field_multi_text.css", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/multi_text\/field_multi_text.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/multi_text\/field_multi_text.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/multi_text\/min\/field_multi_text-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/multi_text\/field_multi_text.min.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/multi_text\/field_multi_text.min.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/multi_text\/min\/field_multi_text.min-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/multi_text\/field_multi_text.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/multi_text\/field_multi_text.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/multi_text\/field_multi_text.scss": { + "createSourceMap": 0, + "debugStyle": 0, + "decimalPrecision": 10, + "fileType": 4, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/multi_text\/field_multi_text.scss", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/css\/field_multi_text.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "useLibsass": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/palette\/field_palette.css": { + "fileType": 16, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/palette\/field_palette.css", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/palette\/field_palette.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/palette\/field_palette.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/palette\/min\/field_palette-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/palette\/field_palette.min.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/palette\/field_palette.min.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/palette\/min\/field_palette.min-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/palette\/field_palette.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/palette\/field_palette.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/palette\/field_palette.scss": { + "createSourceMap": 0, + "debugStyle": 0, + "decimalPrecision": 10, + "fileType": 4, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/palette\/field_palette.scss", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/css\/field_palette.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "useLibsass": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/password\/field_password.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/password\/field_password.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/radio\/field_radio.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/radio\/field_radio.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/raw\/field_raw.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/raw\/field_raw.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/raw\/parsedown.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/raw\/parsedown.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/section\/field_section.css": { + "fileType": 16, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/section\/field_section.css", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/section\/field_section.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/section\/field_section.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/section\/field_section.scss": { + "createSourceMap": 0, + "debugStyle": 0, + "decimalPrecision": 10, + "fileType": 4, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/section\/field_section.scss", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/css\/field_section.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "useLibsass": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/select\/elusive-icons.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/select\/elusive-icons.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/select\/field_select.css": { + "fileType": 16, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/select\/field_select.css", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/select\/field_select.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/select\/field_select.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/select\/min\/field_select-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/select\/field_select.min.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/select\/field_select.min.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/select\/min\/field_select.min-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/select\/field_select.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/select\/field_select.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/select\/field_select.scss": { + "createSourceMap": 0, + "debugStyle": 0, + "decimalPrecision": 10, + "fileType": 4, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/select\/field_select.scss", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/css\/field_select.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "useLibsass": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/select_image\/field_select_image.css": { + "fileType": 16, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/select_image\/field_select_image.css", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/select_image\/field_select_image.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/select_image\/field_select_image.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/select_image\/min\/field_select_image-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/select_image\/field_select_image.min.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/select_image\/field_select_image.min.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/select_image\/min\/field_select_image.min-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/select_image\/field_select_image.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/select_image\/field_select_image.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/select_image\/field_select_image.scss": { + "createSourceMap": 0, + "debugStyle": 0, + "decimalPrecision": 10, + "fileType": 4, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/select_image\/field_select_image.scss", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/css\/field_select_image.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "useLibsass": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/slider\/field_slider.css": { + "fileType": 16, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/slider\/field_slider.css", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/slider\/field_slider.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/slider\/field_slider.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/slider\/min\/field_slider-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/slider\/field_slider.min.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/slider\/field_slider.min.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/slider\/min\/field_slider.min-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/slider\/field_slider.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/slider\/field_slider.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/slider\/field_slider.scss": { + "createSourceMap": 0, + "debugStyle": 0, + "decimalPrecision": 10, + "fileType": 4, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/slider\/field_slider.scss", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/css\/field_slider.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "useLibsass": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/slider\/vendor\/nouislider\/redux.jquery.nouislider.css": { + "fileType": 16, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/slider\/vendor\/nouislider\/redux.jquery.nouislider.css", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/slider\/vendor\/nouislider\/redux.jquery.nouislider.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/slider\/vendor\/nouislider\/redux.jquery.nouislider.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/slider\/vendor\/nouislider\/min\/redux.jquery.nouislider-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/slider\/vendor\/nouislider\/redux.jquery.nouislider.min.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/slider\/vendor\/nouislider\/redux.jquery.nouislider.min.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/slider\/vendor\/nouislider\/min\/redux.jquery.nouislider.min-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/slides\/field_slides.css": { + "fileType": 16, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/slides\/field_slides.css", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/slides\/field_slides.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/slides\/field_slides.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/slides\/min\/field_slides-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/slides\/field_slides.min.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/slides\/field_slides.min.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/slides\/min\/field_slides.min-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/slides\/field_slides.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/slides\/field_slides.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/slides\/field_slides.scss": { + "createSourceMap": 0, + "debugStyle": 0, + "decimalPrecision": 10, + "fileType": 4, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/slides\/field_slides.scss", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/css\/field_slides.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "useLibsass": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/sortable\/field_sortable.css": { + "fileType": 16, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/sortable\/field_sortable.css", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/sortable\/field_sortable.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/sortable\/field_sortable.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/sortable\/min\/field_sortable-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/sortable\/field_sortable.min.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/sortable\/field_sortable.min.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/sortable\/min\/field_sortable.min-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/sortable\/field_sortable.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/sortable\/field_sortable.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/sortable\/field_sortable.scss": { + "createSourceMap": 0, + "debugStyle": 0, + "decimalPrecision": 10, + "fileType": 4, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/sortable\/field_sortable.scss", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/css\/field_sortable.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "useLibsass": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/sorter\/field_sorter.css": { + "fileType": 16, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/sorter\/field_sorter.css", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/sorter\/field_sorter.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/sorter\/field_sorter.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/sorter\/min\/field_sorter-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/sorter\/field_sorter.min.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/sorter\/field_sorter.min.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/sorter\/min\/field_sorter.min-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/sorter\/field_sorter.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/sorter\/field_sorter.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/sorter\/field_sorter.scss": { + "createSourceMap": 0, + "debugStyle": 0, + "decimalPrecision": 10, + "fileType": 4, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/sorter\/field_sorter.scss", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/css\/field_sorter.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "useLibsass": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/spacing\/field_spacing.css": { + "fileType": 16, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/spacing\/field_spacing.css", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/spacing\/field_spacing.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/spacing\/field_spacing.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/spacing\/min\/field_spacing-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/spacing\/field_spacing.min.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/spacing\/field_spacing.min.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/spacing\/min\/field_spacing.min-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/spacing\/field_spacing.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/spacing\/field_spacing.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/spacing\/field_spacing.scss": { + "createSourceMap": 0, + "debugStyle": 0, + "decimalPrecision": 10, + "fileType": 4, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/spacing\/field_spacing.scss", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/css\/field_spacing.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "useLibsass": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/spinner\/arrow_left.png": { + "fileType": 32768, + "ignore": 0, + "ignoreWasSetByUser": 0, + "initialSize": 150, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/spinner\/arrow_left.png", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/spinner\/arrow_left.png", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "processed": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/spinner\/arrow_right.png": { + "fileType": 32768, + "ignore": 0, + "ignoreWasSetByUser": 0, + "initialSize": 154, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/spinner\/arrow_right.png", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/spinner\/arrow_right.png", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "processed": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/spinner\/field_spinner.css": { + "fileType": 16, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/spinner\/field_spinner.css", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/spinner\/field_spinner.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/spinner\/field_spinner.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/spinner\/min\/field_spinner-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/spinner\/field_spinner.min.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/spinner\/field_spinner.min.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/spinner\/min\/field_spinner.min-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/spinner\/field_spinner.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/spinner\/field_spinner.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/spinner\/field_spinner.scss": { + "createSourceMap": 0, + "debugStyle": 0, + "decimalPrecision": 10, + "fileType": 4, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/spinner\/field_spinner.scss", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/css\/field_spinner.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "useLibsass": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/spinner\/vendor\/spinner_custom.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/spinner\/vendor\/spinner_custom.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/spinner\/vendor\/min\/spinner_custom-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/switch\/field_switch.css": { + "fileType": 16, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/switch\/field_switch.css", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/switch\/field_switch.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/switch\/field_switch.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/switch\/min\/field_switch-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/switch\/field_switch.min.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/switch\/field_switch.min.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/switch\/min\/field_switch.min-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/switch\/field_switch.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/switch\/field_switch.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/switch\/field_switch.scss": { + "createSourceMap": 0, + "debugStyle": 0, + "decimalPrecision": 10, + "fileType": 4, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/switch\/field_switch.scss", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/css\/field_switch.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "useLibsass": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/switch\/slider-control.png": { + "fileType": 32768, + "ignore": 0, + "ignoreWasSetByUser": 0, + "initialSize": 1690, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/switch\/slider-control.png", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/switch\/slider-control.png", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "processed": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/text\/field_text.css": { + "fileType": 16, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/text\/field_text.css", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/text\/field_text.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/text\/field_text.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/text\/field_text.scss": { + "createSourceMap": 0, + "debugStyle": 0, + "decimalPrecision": 10, + "fileType": 4, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/text\/field_text.scss", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/css\/field_text.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "useLibsass": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/textarea\/field_textarea.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/textarea\/field_textarea.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/typography\/field_typography.css": { + "fileType": 16, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/typography\/field_typography.css", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/typography\/field_typography.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/typography\/field_typography.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/typography\/min\/field_typography-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/typography\/field_typography.min.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/typography\/field_typography.min.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/typography\/min\/field_typography.min-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/typography\/field_typography.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/typography\/field_typography.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/typography\/field_typography.scss": { + "createSourceMap": 0, + "debugStyle": 0, + "decimalPrecision": 10, + "fileType": 4, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/typography\/field_typography.scss", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/css\/field_typography.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "useLibsass": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/fields\/typography\/googlefonts.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/fields\/typography\/googlefonts.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/lib.redux_instances.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/lib.redux_instances.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/themecheck\/checks\/embedded.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/themecheck\/checks\/embedded.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/themecheck\/checks\/full_package.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/themecheck\/checks\/full_package.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/themecheck\/checks\/index.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/themecheck\/checks\/index.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/themecheck\/class.redux_themecheck.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/themecheck\/class.redux_themecheck.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/themecheck\/css\/admin.css": { + "fileType": 16, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/themecheck\/css\/admin.css", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/themecheck\/index.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/themecheck\/index.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/themecheck\/js\/admin.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/themecheck\/js\/admin.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/themecheck\/js\/min\/admin-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/inc\/themecheck\/lang\/index.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/themecheck\/lang\/index.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/tracking.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/tracking.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/validation\/color\/validation_color.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/validation\/color\/validation_color.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/validation\/color_rgba\/validation_color_rgba.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/validation\/color_rgba\/validation_color_rgba.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/validation\/colorrgba\/validation_colorrgba.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/validation\/colorrgba\/validation_colorrgba.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/validation\/comma_numeric\/validation_comma_numeric.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/validation\/comma_numeric\/validation_comma_numeric.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/validation\/css\/validation_css.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/validation\/css\/validation_css.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/validation\/date\/validation_date.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/validation\/date\/validation_date.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/validation\/email\/validation_email.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/validation\/email\/validation_email.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/validation\/email_not_empty\/validation_email_not_empty.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/validation\/email_not_empty\/validation_email_not_empty.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/validation\/html\/validation_html.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/validation\/html\/validation_html.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/validation\/html_custom\/validation_html_custom.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/validation\/html_custom\/validation_html_custom.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/validation\/js\/validation_js.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/validation\/js\/validation_js.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/validation\/no_html\/validation_no_html.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/validation\/no_html\/validation_no_html.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/validation\/no_special_chars\/validation_no_special_chars.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/validation\/no_special_chars\/validation_no_special_chars.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/validation\/not_empty\/validation_not_empty.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/validation\/not_empty\/validation_not_empty.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/validation\/numeric\/validation_numeric.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/validation\/numeric\/validation_numeric.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/validation\/numeric_not_empty\/validation_numeric_not_empty.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/validation\/numeric_not_empty\/validation_numeric_not_empty.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/validation\/preg_replace\/validation_preg_replace.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/validation\/preg_replace\/validation_preg_replace.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/validation\/str_replace\/validation_str_replace.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/validation\/str_replace\/validation_str_replace.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/validation\/unique_slug\/validation_unique_slug.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/validation\/unique_slug\/validation_unique_slug.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/validation\/url\/validation_url.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/validation\/url\/validation_url.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/welcome\/css\/redux-welcome.css": { + "fileType": 16, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/welcome\/css\/redux-welcome.css", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/welcome\/css\/redux-welcome.scss": { + "createSourceMap": 0, + "debugStyle": 0, + "decimalPrecision": 10, + "fileType": 4, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/welcome\/css\/redux-welcome.scss", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/welcome\/css\/redux-welcome.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "useLibsass": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/welcome\/js\/jquery.easing.min.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/welcome\/js\/jquery.easing.min.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/welcome\/js\/min\/jquery.easing.min-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/inc\/welcome\/js\/redux-welcome-admin.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/welcome\/js\/redux-welcome-admin.js", + "outputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/welcome\/js\/min\/redux-welcome-admin-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/admin\/ReduxCore\/inc\/welcome\/views\/about.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/welcome\/views\/about.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/welcome\/views\/changelog.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/welcome\/views\/changelog.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/welcome\/views\/credits.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/welcome\/views\/credits.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/welcome\/views\/extensions.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/welcome\/views\/extensions.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/welcome\/views\/status_report.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/welcome\/views\/status_report.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/welcome\/views\/support.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/welcome\/views\/support.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/inc\/welcome\/welcome.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/inc\/welcome\/welcome.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/templates\/panel\/container.tpl.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/templates\/panel\/container.tpl.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/templates\/panel\/content.tpl.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/templates\/panel\/content.tpl.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/templates\/panel\/footer.tpl.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/templates\/panel\/footer.tpl.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/templates\/panel\/header.tpl.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/templates\/panel\/header.tpl.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/templates\/panel\/header_stickybar.tpl.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/templates\/panel\/header_stickybar.tpl.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/ReduxCore\/templates\/panel\/menu_container.tpl.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/ReduxCore\/templates\/panel\/menu_container.tpl.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/tests\/bootstrap.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/tests\/bootstrap.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/tests\/includes\/class-tivwp-dm-controller.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/tests\/includes\/class-tivwp-dm-controller.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/tests\/includes\/class-tivwp-dm-notices.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/tests\/includes\/class-tivwp-dm-notices.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/tests\/includes\/class-tivwp-dm.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/tests\/includes\/class-tivwp-dm.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/tests\/test-sample.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/tests\/test-sample.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/tests\/tivwp-dm.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/tests\/tivwp-dm.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/admin\/uninstall.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/admin\/uninstall.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/bones.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/bones.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/brew.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/brew.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/css\/childstyles.css": { + "fileType": 16, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/css\/childstyles.css", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/css\/custom-variables.css": { + "fileType": 16, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/css\/custom-variables.css", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/css\/ie.css": { + "fileType": 16, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/css\/ie.css", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/css\/liquid-slider.css": { + "fileType": 16, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/css\/liquid-slider.css", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/css\/login.css": { + "fileType": 16, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/css\/login.css", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/css\/style.css": { + "fileType": 16, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/css\/style.css", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/custom-post-type.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/custom-post-type.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/images\/apple-icon-touch.png": { + "fileType": 32768, + "ignore": 0, + "ignoreWasSetByUser": 0, + "initialSize": 8439, + "inputAbbreviatedPath": "\/library\/images\/apple-icon-touch.png", + "outputAbbreviatedPath": "\/library\/images\/apple-icon-touch.png", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "processed": 0 + }, + "\/library\/images\/arrow.png": { + "fileType": 32768, + "ignore": 0, + "ignoreWasSetByUser": 0, + "initialSize": 2144, + "inputAbbreviatedPath": "\/library\/images\/arrow.png", + "outputAbbreviatedPath": "\/library\/images\/arrow.png", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "processed": 0 + }, + "\/library\/images\/hal.jpg": { + "fileType": 16384, + "ignore": 0, + "ignoreWasSetByUser": 0, + "initialSize": 17994, + "inputAbbreviatedPath": "\/library\/images\/hal.jpg", + "outputAbbreviatedPath": "\/library\/images\/hal.jpg", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "processed": 0 + }, + "\/library\/images\/pfpublication.png": { + "fileType": 32768, + "ignore": 0, + "ignoreWasSetByUser": 0, + "initialSize": 6222, + "inputAbbreviatedPath": "\/library\/images\/pfpublication.png", + "outputAbbreviatedPath": "\/library\/images\/pfpublication.png", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "processed": 0 + }, + "\/library\/js\/fitvid.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/js\/fitvid.js", + "outputAbbreviatedPath": "\/library\/js\/min\/fitvid-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/js\/jquery-1.11.2.min.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/js\/jquery-1.11.2.min.js", + "outputAbbreviatedPath": "\/library\/js\/min\/jquery-1.11.2.min-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/js\/jquery.easing.1.3.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/js\/jquery.easing.1.3.js", + "outputAbbreviatedPath": "\/library\/js\/min\/jquery.easing.1.3-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/js\/jquery.liquid-slider.min.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/js\/jquery.liquid-slider.min.js", + "outputAbbreviatedPath": "\/library\/js\/min\/jquery.liquid-slider.min-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/js\/jquery.touchSwipe.min.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/js\/jquery.touchSwipe.min.js", + "outputAbbreviatedPath": "\/library\/js\/min\/jquery.touchSwipe.min-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/js\/libs\/bootstrap.min.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/js\/libs\/bootstrap.min.js", + "outputAbbreviatedPath": "\/library\/js\/libs\/min\/bootstrap.min-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/js\/libs\/FitVids.js-master\/component.json": { + "fileType": 524288, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/js\/libs\/FitVids.js-master\/component.json", + "orderOutput": 0, + "outputAbbreviatedPath": "\/library\/js\/libs\/FitVids.js-master\/component-min.json", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1 + }, + "\/library\/js\/libs\/FitVids.js-master\/CONTRIBUTING.md": { + "criticStyle": 0, + "enableFootnotes": 1, + "enableLabels": 1, + "enableSmartQuotes": 1, + "escapeLineBreaks": 0, + "fileType": 4096, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/js\/libs\/FitVids.js-master\/CONTRIBUTING.md", + "maskEmailAddresses": 1, + "outputAbbreviatedPath": "\/library\/js\/libs\/FitVids.js-master\/CONTRIBUTING.html", + "outputFormat": 0, + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "parseMetadata": 1, + "processHTML": 0, + "randomFootnoteNumbers": 0, + "useCompatibilityMode": 0 + }, + "\/library\/js\/libs\/FitVids.js-master\/jquery.fitvids.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/js\/libs\/FitVids.js-master\/jquery.fitvids.js", + "outputAbbreviatedPath": "\/library\/js\/libs\/FitVids.js-master\/min\/jquery.fitvids-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/js\/libs\/modernizr.custom.min.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/js\/libs\/modernizr.custom.min.js", + "outputAbbreviatedPath": "\/library\/js\/libs\/min\/modernizr.custom.min-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/js\/min\/bootstrap.min-min.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/js\/min\/bootstrap.min-min.js", + "outputAbbreviatedPath": "\/library\/js\/min\/min\/bootstrap.min-min-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/js\/min\/jquery.liquid-slider.min-min.js": { + "fileType": 64, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/js\/min\/jquery.liquid-slider.min-min.js", + "outputAbbreviatedPath": "\/library\/js\/min\/min\/jquery.liquid-slider.min-min-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/js\/scripts.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/js\/scripts.js", + "outputAbbreviatedPath": "\/library\/js\/min\/scripts-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/less\/bootstrap\/alerts.less": { + "allowInsecureImports": 0, + "createSourceMap": 0, + "disableJavascript": 0, + "fileType": 1, + "ieCompatibility": 1, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/bootstrap\/alerts.less", + "outputAbbreviatedPath": "\/library\/less\/css\/alerts.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "relativeURLS": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "strictImports": 0, + "strictMath": 0, + "strictUnits": 0 + }, + "\/library\/less\/bootstrap\/badges.less": { + "allowInsecureImports": 0, + "createSourceMap": 0, + "disableJavascript": 0, + "fileType": 1, + "ieCompatibility": 1, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/bootstrap\/badges.less", + "outputAbbreviatedPath": "\/library\/less\/css\/badges.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "relativeURLS": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "strictImports": 0, + "strictMath": 0, + "strictUnits": 0 + }, + "\/library\/less\/bootstrap\/breadcrumbs.less": { + "allowInsecureImports": 0, + "createSourceMap": 0, + "disableJavascript": 0, + "fileType": 1, + "ieCompatibility": 1, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/bootstrap\/breadcrumbs.less", + "outputAbbreviatedPath": "\/library\/less\/css\/breadcrumbs.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "relativeURLS": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "strictImports": 0, + "strictMath": 0, + "strictUnits": 0 + }, + "\/library\/less\/bootstrap\/button-groups.less": { + "allowInsecureImports": 0, + "createSourceMap": 0, + "disableJavascript": 0, + "fileType": 1, + "ieCompatibility": 1, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/bootstrap\/button-groups.less", + "outputAbbreviatedPath": "\/library\/less\/css\/button-groups.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "relativeURLS": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "strictImports": 0, + "strictMath": 0, + "strictUnits": 0 + }, + "\/library\/less\/bootstrap\/buttons.less": { + "allowInsecureImports": 0, + "createSourceMap": 0, + "disableJavascript": 0, + "fileType": 1, + "ieCompatibility": 1, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/bootstrap\/buttons.less", + "outputAbbreviatedPath": "\/library\/less\/css\/buttons.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "relativeURLS": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "strictImports": 0, + "strictMath": 0, + "strictUnits": 0 + }, + "\/library\/less\/bootstrap\/carousel.less": { + "allowInsecureImports": 0, + "createSourceMap": 0, + "disableJavascript": 0, + "fileType": 1, + "ieCompatibility": 1, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/bootstrap\/carousel.less", + "outputAbbreviatedPath": "\/library\/less\/css\/carousel.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "relativeURLS": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "strictImports": 0, + "strictMath": 0, + "strictUnits": 0 + }, + "\/library\/less\/bootstrap\/close.less": { + "allowInsecureImports": 0, + "createSourceMap": 0, + "disableJavascript": 0, + "fileType": 1, + "ieCompatibility": 1, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/bootstrap\/close.less", + "outputAbbreviatedPath": "\/library\/less\/css\/close.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "relativeURLS": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "strictImports": 0, + "strictMath": 0, + "strictUnits": 0 + }, + "\/library\/less\/bootstrap\/code.less": { + "allowInsecureImports": 0, + "createSourceMap": 0, + "disableJavascript": 0, + "fileType": 1, + "ieCompatibility": 1, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/bootstrap\/code.less", + "outputAbbreviatedPath": "\/library\/less\/css\/code.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "relativeURLS": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "strictImports": 0, + "strictMath": 0, + "strictUnits": 0 + }, + "\/library\/less\/bootstrap\/component-animations.less": { + "allowInsecureImports": 0, + "createSourceMap": 0, + "disableJavascript": 0, + "fileType": 1, + "ieCompatibility": 1, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/bootstrap\/component-animations.less", + "outputAbbreviatedPath": "\/library\/less\/css\/component-animations.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "relativeURLS": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "strictImports": 0, + "strictMath": 0, + "strictUnits": 0 + }, + "\/library\/less\/bootstrap\/dropdowns.less": { + "allowInsecureImports": 0, + "createSourceMap": 0, + "disableJavascript": 0, + "fileType": 1, + "ieCompatibility": 1, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/bootstrap\/dropdowns.less", + "outputAbbreviatedPath": "\/library\/less\/css\/dropdowns.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "relativeURLS": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "strictImports": 0, + "strictMath": 0, + "strictUnits": 0 + }, + "\/library\/less\/bootstrap\/forms.less": { + "allowInsecureImports": 0, + "createSourceMap": 0, + "disableJavascript": 0, + "fileType": 1, + "ieCompatibility": 1, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/bootstrap\/forms.less", + "outputAbbreviatedPath": "\/library\/less\/css\/forms.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "relativeURLS": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "strictImports": 0, + "strictMath": 0, + "strictUnits": 0 + }, + "\/library\/less\/bootstrap\/glyphicons.less": { + "allowInsecureImports": 0, + "createSourceMap": 0, + "disableJavascript": 0, + "fileType": 1, + "ieCompatibility": 1, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/bootstrap\/glyphicons.less", + "outputAbbreviatedPath": "\/library\/less\/css\/glyphicons.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "relativeURLS": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "strictImports": 0, + "strictMath": 0, + "strictUnits": 0 + }, + "\/library\/less\/bootstrap\/grid.less": { + "allowInsecureImports": 0, + "createSourceMap": 0, + "disableJavascript": 0, + "fileType": 1, + "ieCompatibility": 1, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/bootstrap\/grid.less", + "outputAbbreviatedPath": "\/library\/less\/css\/grid.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "relativeURLS": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "strictImports": 0, + "strictMath": 0, + "strictUnits": 0 + }, + "\/library\/less\/bootstrap\/input-groups.less": { + "allowInsecureImports": 0, + "createSourceMap": 0, + "disableJavascript": 0, + "fileType": 1, + "ieCompatibility": 1, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/bootstrap\/input-groups.less", + "outputAbbreviatedPath": "\/library\/less\/css\/input-groups.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "relativeURLS": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "strictImports": 0, + "strictMath": 0, + "strictUnits": 0 + }, + "\/library\/less\/bootstrap\/jumbotron.less": { + "allowInsecureImports": 0, + "createSourceMap": 0, + "disableJavascript": 0, + "fileType": 1, + "ieCompatibility": 1, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/bootstrap\/jumbotron.less", + "outputAbbreviatedPath": "\/library\/less\/css\/jumbotron.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "relativeURLS": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "strictImports": 0, + "strictMath": 0, + "strictUnits": 0 + }, + "\/library\/less\/bootstrap\/labels.less": { + "allowInsecureImports": 0, + "createSourceMap": 0, + "disableJavascript": 0, + "fileType": 1, + "ieCompatibility": 1, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/bootstrap\/labels.less", + "outputAbbreviatedPath": "\/library\/less\/css\/labels.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "relativeURLS": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "strictImports": 0, + "strictMath": 0, + "strictUnits": 0 + }, + "\/library\/less\/bootstrap\/list-group.less": { + "allowInsecureImports": 0, + "createSourceMap": 0, + "disableJavascript": 0, + "fileType": 1, + "ieCompatibility": 1, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/bootstrap\/list-group.less", + "outputAbbreviatedPath": "\/library\/less\/css\/list-group.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "relativeURLS": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "strictImports": 0, + "strictMath": 0, + "strictUnits": 0 + }, + "\/library\/less\/bootstrap\/media.less": { + "allowInsecureImports": 0, + "createSourceMap": 0, + "disableJavascript": 0, + "fileType": 1, + "ieCompatibility": 1, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/bootstrap\/media.less", + "outputAbbreviatedPath": "\/library\/less\/css\/media.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "relativeURLS": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "strictImports": 0, + "strictMath": 0, + "strictUnits": 0 + }, + "\/library\/less\/bootstrap\/mixins.less": { + "allowInsecureImports": 0, + "createSourceMap": 0, + "disableJavascript": 0, + "fileType": 1, + "ieCompatibility": 1, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/bootstrap\/mixins.less", + "outputAbbreviatedPath": "\/library\/less\/css\/mixins.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "relativeURLS": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "strictImports": 0, + "strictMath": 0, + "strictUnits": 0 + }, + "\/library\/less\/bootstrap\/modals.less": { + "allowInsecureImports": 0, + "createSourceMap": 0, + "disableJavascript": 0, + "fileType": 1, + "ieCompatibility": 1, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/bootstrap\/modals.less", + "outputAbbreviatedPath": "\/library\/less\/css\/modals.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "relativeURLS": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "strictImports": 0, + "strictMath": 0, + "strictUnits": 0 + }, + "\/library\/less\/bootstrap\/navbar.less": { + "allowInsecureImports": 0, + "createSourceMap": 0, + "disableJavascript": 0, + "fileType": 1, + "ieCompatibility": 1, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/bootstrap\/navbar.less", + "outputAbbreviatedPath": "\/library\/less\/css\/navbar.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "relativeURLS": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "strictImports": 0, + "strictMath": 0, + "strictUnits": 0 + }, + "\/library\/less\/bootstrap\/navs.less": { + "allowInsecureImports": 0, + "createSourceMap": 0, + "disableJavascript": 0, + "fileType": 1, + "ieCompatibility": 1, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/bootstrap\/navs.less", + "outputAbbreviatedPath": "\/library\/less\/css\/navs.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "relativeURLS": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "strictImports": 0, + "strictMath": 0, + "strictUnits": 0 + }, + "\/library\/less\/bootstrap\/normalize.less": { + "allowInsecureImports": 0, + "createSourceMap": 0, + "disableJavascript": 0, + "fileType": 1, + "ieCompatibility": 1, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/bootstrap\/normalize.less", + "outputAbbreviatedPath": "\/library\/less\/css\/normalize.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "relativeURLS": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "strictImports": 0, + "strictMath": 0, + "strictUnits": 0 + }, + "\/library\/less\/bootstrap\/pager.less": { + "allowInsecureImports": 0, + "createSourceMap": 0, + "disableJavascript": 0, + "fileType": 1, + "ieCompatibility": 1, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/bootstrap\/pager.less", + "outputAbbreviatedPath": "\/library\/less\/css\/pager.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "relativeURLS": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "strictImports": 0, + "strictMath": 0, + "strictUnits": 0 + }, + "\/library\/less\/bootstrap\/pagination.less": { + "allowInsecureImports": 0, + "createSourceMap": 0, + "disableJavascript": 0, + "fileType": 1, + "ieCompatibility": 1, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/bootstrap\/pagination.less", + "outputAbbreviatedPath": "\/library\/less\/css\/pagination.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "relativeURLS": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "strictImports": 0, + "strictMath": 0, + "strictUnits": 0 + }, + "\/library\/less\/bootstrap\/panels.less": { + "allowInsecureImports": 0, + "createSourceMap": 0, + "disableJavascript": 0, + "fileType": 1, + "ieCompatibility": 1, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/bootstrap\/panels.less", + "outputAbbreviatedPath": "\/library\/less\/css\/panels.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "relativeURLS": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "strictImports": 0, + "strictMath": 0, + "strictUnits": 0 + }, + "\/library\/less\/bootstrap\/popovers.less": { + "allowInsecureImports": 0, + "createSourceMap": 0, + "disableJavascript": 0, + "fileType": 1, + "ieCompatibility": 1, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/bootstrap\/popovers.less", + "outputAbbreviatedPath": "\/library\/less\/css\/popovers.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "relativeURLS": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "strictImports": 0, + "strictMath": 0, + "strictUnits": 0 + }, + "\/library\/less\/bootstrap\/print.less": { + "allowInsecureImports": 0, + "createSourceMap": 0, + "disableJavascript": 0, + "fileType": 1, + "ieCompatibility": 1, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/bootstrap\/print.less", + "outputAbbreviatedPath": "\/library\/less\/css\/print.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "relativeURLS": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "strictImports": 0, + "strictMath": 0, + "strictUnits": 0 + }, + "\/library\/less\/bootstrap\/progress-bars.less": { + "allowInsecureImports": 0, + "createSourceMap": 0, + "disableJavascript": 0, + "fileType": 1, + "ieCompatibility": 1, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/bootstrap\/progress-bars.less", + "outputAbbreviatedPath": "\/library\/less\/css\/progress-bars.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "relativeURLS": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "strictImports": 0, + "strictMath": 0, + "strictUnits": 0 + }, + "\/library\/less\/bootstrap\/responsive-utilities.less": { + "allowInsecureImports": 0, + "createSourceMap": 0, + "disableJavascript": 0, + "fileType": 1, + "ieCompatibility": 1, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/bootstrap\/responsive-utilities.less", + "outputAbbreviatedPath": "\/library\/less\/css\/responsive-utilities.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "relativeURLS": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "strictImports": 0, + "strictMath": 0, + "strictUnits": 0 + }, + "\/library\/less\/bootstrap\/scaffolding.less": { + "allowInsecureImports": 0, + "createSourceMap": 0, + "disableJavascript": 0, + "fileType": 1, + "ieCompatibility": 1, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/bootstrap\/scaffolding.less", + "outputAbbreviatedPath": "\/library\/less\/css\/scaffolding.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "relativeURLS": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "strictImports": 0, + "strictMath": 0, + "strictUnits": 0 + }, + "\/library\/less\/bootstrap\/tables.less": { + "allowInsecureImports": 0, + "createSourceMap": 0, + "disableJavascript": 0, + "fileType": 1, + "ieCompatibility": 1, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/bootstrap\/tables.less", + "outputAbbreviatedPath": "\/library\/less\/css\/tables.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "relativeURLS": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "strictImports": 0, + "strictMath": 0, + "strictUnits": 0 + }, + "\/library\/less\/bootstrap\/theme.less": { + "allowInsecureImports": 0, + "createSourceMap": 0, + "disableJavascript": 0, + "fileType": 1, + "ieCompatibility": 1, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/bootstrap\/theme.less", + "outputAbbreviatedPath": "\/library\/less\/css\/theme.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "relativeURLS": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "strictImports": 0, + "strictMath": 0, + "strictUnits": 0 + }, + "\/library\/less\/bootstrap\/thumbnails.less": { + "allowInsecureImports": 0, + "createSourceMap": 0, + "disableJavascript": 0, + "fileType": 1, + "ieCompatibility": 1, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/bootstrap\/thumbnails.less", + "outputAbbreviatedPath": "\/library\/less\/css\/thumbnails.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "relativeURLS": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "strictImports": 0, + "strictMath": 0, + "strictUnits": 0 + }, + "\/library\/less\/bootstrap\/tooltip.less": { + "allowInsecureImports": 0, + "createSourceMap": 0, + "disableJavascript": 0, + "fileType": 1, + "ieCompatibility": 1, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/bootstrap\/tooltip.less", + "outputAbbreviatedPath": "\/library\/less\/css\/tooltip.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "relativeURLS": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "strictImports": 0, + "strictMath": 0, + "strictUnits": 0 + }, + "\/library\/less\/bootstrap\/type.less": { + "allowInsecureImports": 0, + "createSourceMap": 0, + "disableJavascript": 0, + "fileType": 1, + "ieCompatibility": 1, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/bootstrap\/type.less", + "outputAbbreviatedPath": "\/library\/less\/css\/type.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "relativeURLS": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "strictImports": 0, + "strictMath": 0, + "strictUnits": 0 + }, + "\/library\/less\/bootstrap\/utilities.less": { + "allowInsecureImports": 0, + "createSourceMap": 0, + "disableJavascript": 0, + "fileType": 1, + "ieCompatibility": 1, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/bootstrap\/utilities.less", + "outputAbbreviatedPath": "\/library\/less\/css\/utilities.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "relativeURLS": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "strictImports": 0, + "strictMath": 0, + "strictUnits": 0 + }, + "\/library\/less\/bootstrap\/wells.less": { + "allowInsecureImports": 0, + "createSourceMap": 0, + "disableJavascript": 0, + "fileType": 1, + "ieCompatibility": 1, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/bootstrap\/wells.less", + "outputAbbreviatedPath": "\/library\/less\/css\/wells.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "relativeURLS": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "strictImports": 0, + "strictMath": 0, + "strictUnits": 0 + }, + "\/library\/less\/brew\/body.less": { + "allowInsecureImports": 0, + "createSourceMap": 0, + "disableJavascript": 0, + "fileType": 1, + "ieCompatibility": 1, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/brew\/body.less", + "outputAbbreviatedPath": "\/library\/less\/css\/body.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "relativeURLS": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "strictImports": 0, + "strictMath": 0, + "strictUnits": 0 + }, + "\/library\/less\/brew\/brew.less": { + "allowInsecureImports": 0, + "createSourceMap": 0, + "disableJavascript": 0, + "fileType": 1, + "ieCompatibility": 1, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/brew\/brew.less", + "outputAbbreviatedPath": "\/library\/less\/css\/brew.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "relativeURLS": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "strictImports": 0, + "strictMath": 0, + "strictUnits": 0 + }, + "\/library\/less\/brew\/comments.less": { + "allowInsecureImports": 0, + "createSourceMap": 0, + "disableJavascript": 0, + "fileType": 1, + "ieCompatibility": 1, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/brew\/comments.less", + "outputAbbreviatedPath": "\/library\/less\/css\/comments.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "relativeURLS": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "strictImports": 0, + "strictMath": 0, + "strictUnits": 0 + }, + "\/library\/less\/brew\/components.less": { + "allowInsecureImports": 0, + "createSourceMap": 0, + "disableJavascript": 0, + "fileType": 1, + "ieCompatibility": 1, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/brew\/components.less", + "outputAbbreviatedPath": "\/library\/less\/css\/components.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "relativeURLS": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "strictImports": 0, + "strictMath": 0, + "strictUnits": 0 + }, + "\/library\/less\/brew\/content.less": { + "allowInsecureImports": 0, + "createSourceMap": 0, + "disableJavascript": 0, + "fileType": 1, + "ieCompatibility": 1, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/brew\/content.less", + "outputAbbreviatedPath": "\/library\/less\/css\/content.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "relativeURLS": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "strictImports": 0, + "strictMath": 0, + "strictUnits": 0 + }, + "\/library\/less\/brew\/footer.less": { + "allowInsecureImports": 0, + "createSourceMap": 0, + "disableJavascript": 0, + "fileType": 1, + "ieCompatibility": 1, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/brew\/footer.less", + "outputAbbreviatedPath": "\/library\/less\/css\/footer.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "relativeURLS": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "strictImports": 0, + "strictMath": 0, + "strictUnits": 0 + }, + "\/library\/less\/brew\/form.less": { + "allowInsecureImports": 0, + "createSourceMap": 0, + "disableJavascript": 0, + "fileType": 1, + "ieCompatibility": 1, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/brew\/form.less", + "outputAbbreviatedPath": "\/library\/less\/css\/form.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "relativeURLS": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "strictImports": 0, + "strictMath": 0, + "strictUnits": 0 + }, + "\/library\/less\/brew\/global.less": { + "allowInsecureImports": 0, + "createSourceMap": 0, + "disableJavascript": 0, + "fileType": 1, + "ieCompatibility": 1, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/brew\/global.less", + "outputAbbreviatedPath": "\/library\/less\/css\/global.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "relativeURLS": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "strictImports": 0, + "strictMath": 0, + "strictUnits": 0 + }, + "\/library\/less\/brew\/nav.less": { + "allowInsecureImports": 0, + "createSourceMap": 0, + "disableJavascript": 0, + "fileType": 1, + "ieCompatibility": 1, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/brew\/nav.less", + "outputAbbreviatedPath": "\/library\/less\/css\/nav.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "relativeURLS": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "strictImports": 0, + "strictMath": 0, + "strictUnits": 0 + }, + "\/library\/less\/brew\/sidebar.less": { + "allowInsecureImports": 0, + "createSourceMap": 0, + "disableJavascript": 0, + "fileType": 1, + "ieCompatibility": 1, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/brew\/sidebar.less", + "outputAbbreviatedPath": "\/library\/less\/css\/sidebar.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "relativeURLS": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "strictImports": 0, + "strictMath": 0, + "strictUnits": 0 + }, + "\/library\/less\/brew\/tables.less": { + "allowInsecureImports": 0, + "createSourceMap": 0, + "disableJavascript": 0, + "fileType": 1, + "ieCompatibility": 1, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/brew\/tables.less", + "outputAbbreviatedPath": "\/library\/less\/css\/tables.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "relativeURLS": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "strictImports": 0, + "strictMath": 0, + "strictUnits": 0 + }, + "\/library\/less\/brew\/wp-core.less": { + "allowInsecureImports": 0, + "createSourceMap": 0, + "disableJavascript": 0, + "fileType": 1, + "ieCompatibility": 1, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/brew\/wp-core.less", + "outputAbbreviatedPath": "\/library\/less\/css\/wp-core.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "relativeURLS": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "strictImports": 0, + "strictMath": 0, + "strictUnits": 0 + }, + "\/library\/less\/css\/pf-footer.css": { + "fileType": 16, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/css\/pf-footer.css", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/less\/css\/pf-nav.css": { + "fileType": 16, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/css\/pf-nav.css", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/less\/css\/sidebar.css": { + "fileType": 16, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/css\/sidebar.css", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/less\/custom-variables.less": { + "allowInsecureImports": 0, + "createSourceMap": 0, + "disableJavascript": 0, + "fileType": 1, + "ieCompatibility": 1, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/custom-variables.less", + "outputAbbreviatedPath": "\/library\/css\/custom-variables.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "relativeURLS": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "strictImports": 0, + "strictMath": 0, + "strictUnits": 0 + }, + "\/library\/less\/metabox\/example-functions.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/metabox\/example-functions.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/less\/metabox\/helpers\/cmb_Meta_Box_ajax.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/metabox\/helpers\/cmb_Meta_Box_ajax.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/less\/metabox\/helpers\/cmb_Meta_Box_Sanitize.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/metabox\/helpers\/cmb_Meta_Box_Sanitize.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/less\/metabox\/helpers\/cmb_Meta_Box_Show_Filters.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/metabox\/helpers\/cmb_Meta_Box_Show_Filters.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/less\/metabox\/helpers\/cmb_Meta_Box_types.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/metabox\/helpers\/cmb_Meta_Box_types.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/less\/metabox\/images\/ico-delete.png": { + "fileType": 32768, + "ignore": 0, + "ignoreWasSetByUser": 0, + "initialSize": 715, + "inputAbbreviatedPath": "\/library\/less\/metabox\/images\/ico-delete.png", + "outputAbbreviatedPath": "\/library\/less\/metabox\/images\/ico-delete.png", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "processed": 0 + }, + "\/library\/less\/metabox\/images\/ui-bg_flat_0_aaaaaa_40x100.png": { + "fileType": 32768, + "ignore": 0, + "ignoreWasSetByUser": 0, + "initialSize": 180, + "inputAbbreviatedPath": "\/library\/less\/metabox\/images\/ui-bg_flat_0_aaaaaa_40x100.png", + "outputAbbreviatedPath": "\/library\/less\/metabox\/images\/ui-bg_flat_0_aaaaaa_40x100.png", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "processed": 0 + }, + "\/library\/less\/metabox\/images\/ui-bg_flat_75_ffffff_40x100.png": { + "fileType": 32768, + "ignore": 0, + "ignoreWasSetByUser": 0, + "initialSize": 178, + "inputAbbreviatedPath": "\/library\/less\/metabox\/images\/ui-bg_flat_75_ffffff_40x100.png", + "outputAbbreviatedPath": "\/library\/less\/metabox\/images\/ui-bg_flat_75_ffffff_40x100.png", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "processed": 0 + }, + "\/library\/less\/metabox\/images\/ui-bg_glass_55_fbf9ee_1x400.png": { + "fileType": 32768, + "ignore": 0, + "ignoreWasSetByUser": 0, + "initialSize": 120, + "inputAbbreviatedPath": "\/library\/less\/metabox\/images\/ui-bg_glass_55_fbf9ee_1x400.png", + "outputAbbreviatedPath": "\/library\/less\/metabox\/images\/ui-bg_glass_55_fbf9ee_1x400.png", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "processed": 0 + }, + "\/library\/less\/metabox\/images\/ui-bg_glass_65_ffffff_1x400.png": { + "fileType": 32768, + "ignore": 0, + "ignoreWasSetByUser": 0, + "initialSize": 105, + "inputAbbreviatedPath": "\/library\/less\/metabox\/images\/ui-bg_glass_65_ffffff_1x400.png", + "outputAbbreviatedPath": "\/library\/less\/metabox\/images\/ui-bg_glass_65_ffffff_1x400.png", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "processed": 0 + }, + "\/library\/less\/metabox\/images\/ui-bg_glass_75_dadada_1x400.png": { + "fileType": 32768, + "ignore": 0, + "ignoreWasSetByUser": 0, + "initialSize": 111, + "inputAbbreviatedPath": "\/library\/less\/metabox\/images\/ui-bg_glass_75_dadada_1x400.png", + "outputAbbreviatedPath": "\/library\/less\/metabox\/images\/ui-bg_glass_75_dadada_1x400.png", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "processed": 0 + }, + "\/library\/less\/metabox\/images\/ui-bg_glass_75_e6e6e6_1x400.png": { + "fileType": 32768, + "ignore": 0, + "ignoreWasSetByUser": 0, + "initialSize": 110, + "inputAbbreviatedPath": "\/library\/less\/metabox\/images\/ui-bg_glass_75_e6e6e6_1x400.png", + "outputAbbreviatedPath": "\/library\/less\/metabox\/images\/ui-bg_glass_75_e6e6e6_1x400.png", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "processed": 0 + }, + "\/library\/less\/metabox\/images\/ui-bg_glass_95_fef1ec_1x400.png": { + "fileType": 32768, + "ignore": 0, + "ignoreWasSetByUser": 0, + "initialSize": 119, + "inputAbbreviatedPath": "\/library\/less\/metabox\/images\/ui-bg_glass_95_fef1ec_1x400.png", + "outputAbbreviatedPath": "\/library\/less\/metabox\/images\/ui-bg_glass_95_fef1ec_1x400.png", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "processed": 0 + }, + "\/library\/less\/metabox\/images\/ui-bg_highlight-soft_75_cccccc_1x100.png": { + "fileType": 32768, + "ignore": 0, + "ignoreWasSetByUser": 0, + "initialSize": 101, + "inputAbbreviatedPath": "\/library\/less\/metabox\/images\/ui-bg_highlight-soft_75_cccccc_1x100.png", + "outputAbbreviatedPath": "\/library\/less\/metabox\/images\/ui-bg_highlight-soft_75_cccccc_1x100.png", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "processed": 0 + }, + "\/library\/less\/metabox\/images\/ui-icons_222222_256x240.png": { + "fileType": 32768, + "ignore": 0, + "ignoreWasSetByUser": 0, + "initialSize": 4369, + "inputAbbreviatedPath": "\/library\/less\/metabox\/images\/ui-icons_222222_256x240.png", + "outputAbbreviatedPath": "\/library\/less\/metabox\/images\/ui-icons_222222_256x240.png", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "processed": 0 + }, + "\/library\/less\/metabox\/images\/ui-icons_2e83ff_256x240.png": { + "fileType": 32768, + "ignore": 0, + "ignoreWasSetByUser": 0, + "initialSize": 4369, + "inputAbbreviatedPath": "\/library\/less\/metabox\/images\/ui-icons_2e83ff_256x240.png", + "outputAbbreviatedPath": "\/library\/less\/metabox\/images\/ui-icons_2e83ff_256x240.png", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "processed": 0 + }, + "\/library\/less\/metabox\/images\/ui-icons_454545_256x240.png": { + "fileType": 32768, + "ignore": 0, + "ignoreWasSetByUser": 0, + "initialSize": 4369, + "inputAbbreviatedPath": "\/library\/less\/metabox\/images\/ui-icons_454545_256x240.png", + "outputAbbreviatedPath": "\/library\/less\/metabox\/images\/ui-icons_454545_256x240.png", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "processed": 0 + }, + "\/library\/less\/metabox\/images\/ui-icons_888888_256x240.png": { + "fileType": 32768, + "ignore": 0, + "ignoreWasSetByUser": 0, + "initialSize": 5355, + "inputAbbreviatedPath": "\/library\/less\/metabox\/images\/ui-icons_888888_256x240.png", + "outputAbbreviatedPath": "\/library\/less\/metabox\/images\/ui-icons_888888_256x240.png", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "processed": 0 + }, + "\/library\/less\/metabox\/images\/ui-icons_cd0a0a_256x240.png": { + "fileType": 32768, + "ignore": 0, + "ignoreWasSetByUser": 0, + "initialSize": 4369, + "inputAbbreviatedPath": "\/library\/less\/metabox\/images\/ui-icons_cd0a0a_256x240.png", + "outputAbbreviatedPath": "\/library\/less\/metabox\/images\/ui-icons_cd0a0a_256x240.png", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "processed": 0 + }, + "\/library\/less\/metabox\/init.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/metabox\/init.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/less\/metabox\/js\/cmb.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/metabox\/js\/cmb.js", + "outputAbbreviatedPath": "\/library\/less\/metabox\/js\/min\/cmb-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/less\/metabox\/js\/cmb.min.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/metabox\/js\/cmb.min.js", + "outputAbbreviatedPath": "\/library\/less\/metabox\/js\/min\/cmb.min-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/less\/metabox\/js\/jquery.timePicker.min.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/metabox\/js\/jquery.timePicker.min.js", + "outputAbbreviatedPath": "\/library\/less\/metabox\/js\/min\/jquery.timePicker.min-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/less\/metabox\/readme.md": { + "criticStyle": 0, + "enableFootnotes": 1, + "enableLabels": 1, + "enableSmartQuotes": 1, + "escapeLineBreaks": 0, + "fileType": 4096, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/metabox\/readme.md", + "maskEmailAddresses": 1, + "outputAbbreviatedPath": "\/library\/less\/metabox\/readme.html", + "outputFormat": 0, + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "parseMetadata": 1, + "processHTML": 0, + "randomFootnoteNumbers": 0, + "useCompatibilityMode": 0 + }, + "\/library\/less\/metabox\/style.css": { + "fileType": 16, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/metabox\/style.css", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/less\/metabox\/style.min.css": { + "fileType": 16, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/metabox\/style.min.css", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/less\/other\/_2x.less": { + "allowInsecureImports": 0, + "createSourceMap": 0, + "disableJavascript": 0, + "fileType": 1, + "ieCompatibility": 1, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/other\/_2x.less", + "outputAbbreviatedPath": "\/library\/less\/css\/_2x.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "relativeURLS": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "strictImports": 0, + "strictMath": 0, + "strictUnits": 0 + }, + "\/library\/less\/other\/ie.less": { + "allowInsecureImports": 0, + "createSourceMap": 0, + "disableJavascript": 0, + "fileType": 1, + "ieCompatibility": 1, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/other\/ie.less", + "outputAbbreviatedPath": "\/library\/less\/css\/ie.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "relativeURLS": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "strictImports": 0, + "strictMath": 0, + "strictUnits": 0 + }, + "\/library\/less\/other\/login.less": { + "allowInsecureImports": 0, + "createSourceMap": 0, + "disableJavascript": 0, + "fileType": 1, + "ieCompatibility": 1, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/other\/login.less", + "outputAbbreviatedPath": "\/library\/less\/css\/login.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "relativeURLS": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "strictImports": 0, + "strictMath": 0, + "strictUnits": 0 + }, + "\/library\/less\/PFStyles\/pf-general.less": { + "allowInsecureImports": 0, + "createSourceMap": 0, + "disableJavascript": 0, + "fileType": 1, + "ieCompatibility": 1, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/PFStyles\/pf-general.less", + "outputAbbreviatedPath": "\/library\/less\/css\/pf-general.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "relativeURLS": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "strictImports": 0, + "strictMath": 0, + "strictUnits": 0 + }, + "\/library\/less\/PFStyles\/pf-homepage.less": { + "allowInsecureImports": 0, + "createSourceMap": 0, + "disableJavascript": 0, + "fileType": 1, + "ieCompatibility": 1, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/PFStyles\/pf-homepage.less", + "outputAbbreviatedPath": "\/library\/less\/css\/pf-homepage.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "relativeURLS": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "strictImports": 0, + "strictMath": 0, + "strictUnits": 0 + }, + "\/library\/less\/PFStyles\/pf-nav.less": { + "allowInsecureImports": 0, + "createSourceMap": 0, + "disableJavascript": 0, + "fileType": 1, + "ieCompatibility": 1, + "ignore": 1, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/PFStyles\/pf-nav.less", + "outputAbbreviatedPath": "\/library\/less\/css\/pf-nav.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "relativeURLS": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "strictImports": 0, + "strictMath": 0, + "strictUnits": 0 + }, + "\/library\/less\/style.less": { + "allowInsecureImports": 0, + "createSourceMap": 0, + "disableJavascript": 0, + "fileType": 1, + "ieCompatibility": 1, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/style.less", + "outputAbbreviatedPath": "\/library\/css\/style.css", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "relativeURLS": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "strictImports": 0, + "strictMath": 0, + "strictUnits": 0 + }, + "\/library\/less\/translation\/translation.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/less\/translation\/translation.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/metabox\/example-functions.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/metabox\/example-functions.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/metabox\/helpers\/cmb_Meta_Box_ajax.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/metabox\/helpers\/cmb_Meta_Box_ajax.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/metabox\/helpers\/cmb_Meta_Box_Sanitize.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/metabox\/helpers\/cmb_Meta_Box_Sanitize.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/metabox\/helpers\/cmb_Meta_Box_Show_Filters.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/metabox\/helpers\/cmb_Meta_Box_Show_Filters.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/metabox\/helpers\/cmb_Meta_Box_types.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/metabox\/helpers\/cmb_Meta_Box_types.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/metabox\/images\/ico-delete.png": { + "fileType": 32768, + "ignore": 0, + "ignoreWasSetByUser": 0, + "initialSize": 715, + "inputAbbreviatedPath": "\/library\/metabox\/images\/ico-delete.png", + "outputAbbreviatedPath": "\/library\/metabox\/images\/ico-delete.png", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "processed": 0 + }, + "\/library\/metabox\/images\/ui-bg_flat_0_aaaaaa_40x100.png": { + "fileType": 32768, + "ignore": 0, + "ignoreWasSetByUser": 0, + "initialSize": 180, + "inputAbbreviatedPath": "\/library\/metabox\/images\/ui-bg_flat_0_aaaaaa_40x100.png", + "outputAbbreviatedPath": "\/library\/metabox\/images\/ui-bg_flat_0_aaaaaa_40x100.png", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "processed": 0 + }, + "\/library\/metabox\/images\/ui-bg_flat_75_ffffff_40x100.png": { + "fileType": 32768, + "ignore": 0, + "ignoreWasSetByUser": 0, + "initialSize": 178, + "inputAbbreviatedPath": "\/library\/metabox\/images\/ui-bg_flat_75_ffffff_40x100.png", + "outputAbbreviatedPath": "\/library\/metabox\/images\/ui-bg_flat_75_ffffff_40x100.png", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "processed": 0 + }, + "\/library\/metabox\/images\/ui-bg_glass_55_fbf9ee_1x400.png": { + "fileType": 32768, + "ignore": 0, + "ignoreWasSetByUser": 0, + "initialSize": 120, + "inputAbbreviatedPath": "\/library\/metabox\/images\/ui-bg_glass_55_fbf9ee_1x400.png", + "outputAbbreviatedPath": "\/library\/metabox\/images\/ui-bg_glass_55_fbf9ee_1x400.png", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "processed": 0 + }, + "\/library\/metabox\/images\/ui-bg_glass_65_ffffff_1x400.png": { + "fileType": 32768, + "ignore": 0, + "ignoreWasSetByUser": 0, + "initialSize": 105, + "inputAbbreviatedPath": "\/library\/metabox\/images\/ui-bg_glass_65_ffffff_1x400.png", + "outputAbbreviatedPath": "\/library\/metabox\/images\/ui-bg_glass_65_ffffff_1x400.png", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "processed": 0 + }, + "\/library\/metabox\/images\/ui-bg_glass_75_dadada_1x400.png": { + "fileType": 32768, + "ignore": 0, + "ignoreWasSetByUser": 0, + "initialSize": 111, + "inputAbbreviatedPath": "\/library\/metabox\/images\/ui-bg_glass_75_dadada_1x400.png", + "outputAbbreviatedPath": "\/library\/metabox\/images\/ui-bg_glass_75_dadada_1x400.png", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "processed": 0 + }, + "\/library\/metabox\/images\/ui-bg_glass_75_e6e6e6_1x400.png": { + "fileType": 32768, + "ignore": 0, + "ignoreWasSetByUser": 0, + "initialSize": 110, + "inputAbbreviatedPath": "\/library\/metabox\/images\/ui-bg_glass_75_e6e6e6_1x400.png", + "outputAbbreviatedPath": "\/library\/metabox\/images\/ui-bg_glass_75_e6e6e6_1x400.png", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "processed": 0 + }, + "\/library\/metabox\/images\/ui-bg_glass_95_fef1ec_1x400.png": { + "fileType": 32768, + "ignore": 0, + "ignoreWasSetByUser": 0, + "initialSize": 119, + "inputAbbreviatedPath": "\/library\/metabox\/images\/ui-bg_glass_95_fef1ec_1x400.png", + "outputAbbreviatedPath": "\/library\/metabox\/images\/ui-bg_glass_95_fef1ec_1x400.png", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "processed": 0 + }, + "\/library\/metabox\/images\/ui-bg_highlight-soft_75_cccccc_1x100.png": { + "fileType": 32768, + "ignore": 0, + "ignoreWasSetByUser": 0, + "initialSize": 101, + "inputAbbreviatedPath": "\/library\/metabox\/images\/ui-bg_highlight-soft_75_cccccc_1x100.png", + "outputAbbreviatedPath": "\/library\/metabox\/images\/ui-bg_highlight-soft_75_cccccc_1x100.png", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "processed": 0 + }, + "\/library\/metabox\/images\/ui-icons_222222_256x240.png": { + "fileType": 32768, + "ignore": 0, + "ignoreWasSetByUser": 0, + "initialSize": 4369, + "inputAbbreviatedPath": "\/library\/metabox\/images\/ui-icons_222222_256x240.png", + "outputAbbreviatedPath": "\/library\/metabox\/images\/ui-icons_222222_256x240.png", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "processed": 0 + }, + "\/library\/metabox\/images\/ui-icons_2e83ff_256x240.png": { + "fileType": 32768, + "ignore": 0, + "ignoreWasSetByUser": 0, + "initialSize": 4369, + "inputAbbreviatedPath": "\/library\/metabox\/images\/ui-icons_2e83ff_256x240.png", + "outputAbbreviatedPath": "\/library\/metabox\/images\/ui-icons_2e83ff_256x240.png", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "processed": 0 + }, + "\/library\/metabox\/images\/ui-icons_454545_256x240.png": { + "fileType": 32768, + "ignore": 0, + "ignoreWasSetByUser": 0, + "initialSize": 4369, + "inputAbbreviatedPath": "\/library\/metabox\/images\/ui-icons_454545_256x240.png", + "outputAbbreviatedPath": "\/library\/metabox\/images\/ui-icons_454545_256x240.png", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "processed": 0 + }, + "\/library\/metabox\/images\/ui-icons_888888_256x240.png": { + "fileType": 32768, + "ignore": 0, + "ignoreWasSetByUser": 0, + "initialSize": 5355, + "inputAbbreviatedPath": "\/library\/metabox\/images\/ui-icons_888888_256x240.png", + "outputAbbreviatedPath": "\/library\/metabox\/images\/ui-icons_888888_256x240.png", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "processed": 0 + }, + "\/library\/metabox\/images\/ui-icons_cd0a0a_256x240.png": { + "fileType": 32768, + "ignore": 0, + "ignoreWasSetByUser": 0, + "initialSize": 4369, + "inputAbbreviatedPath": "\/library\/metabox\/images\/ui-icons_cd0a0a_256x240.png", + "outputAbbreviatedPath": "\/library\/metabox\/images\/ui-icons_cd0a0a_256x240.png", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "processed": 0 + }, + "\/library\/metabox\/init.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/metabox\/init.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/metabox\/js\/cmb.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/metabox\/js\/cmb.js", + "outputAbbreviatedPath": "\/library\/metabox\/js\/min\/cmb-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/metabox\/js\/cmb.min.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/metabox\/js\/cmb.min.js", + "outputAbbreviatedPath": "\/library\/metabox\/js\/min\/cmb.min-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/metabox\/js\/jquery.timePicker.min.js": { + "fileType": 64, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/metabox\/js\/jquery.timePicker.min.js", + "outputAbbreviatedPath": "\/library\/metabox\/js\/min\/jquery.timePicker.min-min.js", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 1, + "syntaxCheckerStyle": 1 + }, + "\/library\/metabox\/readme.md": { + "criticStyle": 0, + "enableFootnotes": 1, + "enableLabels": 1, + "enableSmartQuotes": 1, + "escapeLineBreaks": 0, + "fileType": 4096, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/metabox\/readme.md", + "maskEmailAddresses": 1, + "outputAbbreviatedPath": "\/library\/metabox\/readme.html", + "outputFormat": 0, + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "parseMetadata": 1, + "processHTML": 0, + "randomFootnoteNumbers": 0, + "useCompatibilityMode": 0 + }, + "\/library\/metabox\/style.css": { + "fileType": 16, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/metabox\/style.css", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/metabox\/style.min.css": { + "fileType": 16, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/metabox\/style.min.css", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/navwalker.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/navwalker.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/option-config.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/option-config.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/library\/translation\/translation.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/library\/translation\/translation.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/page-archive.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/page-archive.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/page-full-width.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/page-full-width.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/page-home.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/page-home.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/page.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/page.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/README.md": { + "criticStyle": 0, + "enableFootnotes": 1, + "enableLabels": 1, + "enableSmartQuotes": 1, + "escapeLineBreaks": 0, + "fileType": 4096, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/README.md", + "maskEmailAddresses": 1, + "outputAbbreviatedPath": "\/README.html", + "outputFormat": 0, + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "outputStyle": 0, + "parseMetadata": 1, + "processHTML": 0, + "randomFootnoteNumbers": 0, + "useCompatibilityMode": 0 + }, + "\/screenshot.jpg": { + "fileType": 16384, + "ignore": 0, + "ignoreWasSetByUser": 0, + "initialSize": 103571, + "inputAbbreviatedPath": "\/screenshot.jpg", + "outputAbbreviatedPath": "\/screenshot.jpg", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0, + "processed": 0 + }, + "\/search.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/search.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/searchform.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/searchform.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/sidebar.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/sidebar.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/single-custom_type.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/single-custom_type.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/single.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/single.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/style.css": { + "fileType": 16, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/style.css", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + }, + "\/taxonomy-custom_cat.php": { + "fileType": 8192, + "ignore": 0, + "ignoreWasSetByUser": 0, + "inputAbbreviatedPath": "\/taxonomy-custom_cat.php", + "outputAbbreviatedPath": "No Output Path", + "outputPathIsOutsideProject": 0, + "outputPathIsSetByUser": 0 + } + }, +"hooks": [ + ], +"lastSavedByUser": "Mandy Regan", +"manualImportLinks": { + }, +"projectAttributes": { + "bowerAbbreviatedPath": "", + "displayValue": "PressForward-TurnKey-Theme", + "displayValueWasSetByUser": 0, + "iconImageName": "pencil_yellow" + }, +"projectSettings": { + "alwaysUseExternalServer": 0, + "animateCSSInjections": 1, + "autoApplyPSLanguageSettingsStyle": 0, + "autoprefixerBrowserString": "> 1%, last 2 versions, Firefox ESR, Opera 12.1", + "autoSyncProjectSettingsFile": 1, + "browserRefreshDelay": 0, + "coffeeAutoOutputPathEnabled": 1, + "coffeeAutoOutputPathFilenamePattern": "*.js", + "coffeeAutoOutputPathRelativePath": "", + "coffeeAutoOutputPathReplace1": "", + "coffeeAutoOutputPathReplace2": "", + "coffeeAutoOutputPathStyle": 0, + "coffeeCreateSourceMap": 0, + "coffeeLintFlags2": { + "arrow_spacing": { + "active": 0, + "flagValue": -1 + }, + "camel_case_classes": { + "active": 1, + "flagValue": -1 + }, + "colon_assignment_spacing": { + "active": 0, + "flagValue": 1 + }, + "cyclomatic_complexity": { + "active": 0, + "flagValue": 10 + }, + "duplicate_key": { + "active": 1, + "flagValue": -1 + }, + "empty_constructor_needs_parens": { + "active": 0, + "flagValue": -1 + }, + "ensure_comprehensions": { + "active": 1, + "flagValue": -1 + }, + "indentation": { + "active": 1, + "flagValue": 2 + }, + "line_endings": { + "active": 0, + "flagValue": 0 + }, + "max_line_length": { + "active": 0, + "flagValue": 150 + }, + "missing_fat_arrows": { + "active": 0, + "flagValue": -1 + }, + "newlines_after_classes": { + "active": 0, + "flagValue": 3 + }, + "no_backticks": { + "active": 1, + "flagValue": -1 + }, + "no_debugger": { + "active": 1, + "flagValue": -1 + }, + "no_empty_functions": { + "active": 0, + "flagValue": -1 + }, + "no_empty_param_list": { + "active": 0, + "flagValue": -1 + }, + "no_implicit_braces": { + "active": 1, + "flagValue": -1 + }, + "no_implicit_parens": { + "active": 0, + "flagValue": -1 + }, + "no_interpolation_in_single_quotes": { + "active": 0, + "flagValue": -1 + }, + "no_plusplus": { + "active": 0, + "flagValue": -1 + }, + "no_stand_alone_at": { + "active": 1, + "flagValue": -1 + }, + "no_tabs": { + "active": 1, + "flagValue": -1 + }, + "no_throwing_strings": { + "active": 1, + "flagValue": -1 + }, + "no_trailing_semicolons": { + "active": 1, + "flagValue": -1 + }, + "no_trailing_whitespace": { + "active": 1, + "flagValue": -1 + }, + "no_unnecessary_double_quotes": { + "active": 0, + "flagValue": -1 + }, + "no_unnecessary_fat_arrows": { + "active": 1, + "flagValue": -1 + }, + "non_empty_constructor_needs_parens": { + "active": 0, + "flagValue": -1 + }, + "prefer_english_operator": { + "active": 0, + "flagValue": -1 + }, + "space_operators": { + "active": 0, + "flagValue": -1 + }, + "spacing_after_comma": { + "active": 1, + "flagValue": -1 + } + }, + "coffeeMinifyOutput": 1, + "coffeeOutputStyle": 0, + "coffeeSyntaxCheckerStyle": 1, + "externalServerAddress": "http:\/\/localhost:8888", + "externalServerPreviewPathAddition": "", + "genericWebpageFileExtensionsString": "html, htm, shtml, shtm, xhtml, php, jsp, asp, aspx, erb, ctp", + "hamlAutoOutputPathEnabled": 1, + "hamlAutoOutputPathFilenamePattern": "*.html", + "hamlAutoOutputPathRelativePath": "", + "hamlAutoOutputPathReplace1": "", + "hamlAutoOutputPathReplace2": "", + "hamlAutoOutputPathStyle": 0, + "hamlEscapeHTMLCharacters": 0, + "hamlNoEscapeInAttributes": 0, + "hamlOutputFormat": 2, + "hamlOutputStyle": 0, + "hamlUseCDATA": 0, + "hamlUseDoubleQuotes": 0, + "hamlUseUnixNewlines": 0, + "jadeAutoOutputPathEnabled": 1, + "jadeAutoOutputPathFilenamePattern": "*.html", + "jadeAutoOutputPathRelativePath": "", + "jadeAutoOutputPathReplace1": "", + "jadeAutoOutputPathReplace2": "", + "jadeAutoOutputPathStyle": 0, + "jadeCompileDebug": 1, + "jadeOutputStyle": 0, + "javascriptAutoOutputPathEnabled": 1, + "javascriptAutoOutputPathFilenamePattern": "*-min.js", + "javascriptAutoOutputPathRelativePath": "\/min", + "javascriptAutoOutputPathReplace1": "", + "javascriptAutoOutputPathReplace2": "", + "javascriptAutoOutputPathStyle": 2, + "javascriptCreateSourceMap": 1, + "javascriptOutputStyle": 1, + "javascriptSyntaxCheckerStyle": 1, + "jsCheckerReservedNamesString": "", + "jsHintFlags2": { + "asi": { + "active": 0, + "flagValue": -1 + }, + "bitwise": { + "active": 1, + "flagValue": -1 + }, + "boss": { + "active": 0, + "flagValue": -1 + }, + "browser": { + "active": 1, + "flagValue": -1 + }, + "browserify": { + "active": 0, + "flagValue": -1 + }, + "camelcase": { + "active": 0, + "flagValue": -1 + }, + "couch": { + "active": 0, + "flagValue": -1 + }, + "curly": { + "active": 1, + "flagValue": -1 + }, + "debug": { + "active": 0, + "flagValue": -1 + }, + "devel": { + "active": 0, + "flagValue": -1 + }, + "dojo": { + "active": 0, + "flagValue": -1 + }, + "elision": { + "active": 1, + "flagValue": -1 + }, + "eqeqeq": { + "active": 1, + "flagValue": -1 + }, + "eqnull": { + "active": 0, + "flagValue": -1 + }, + "es3": { + "active": 0, + "flagValue": -1 + }, + "esnext": { + "active": 0, + "flagValue": -1 + }, + "evil": { + "active": 0, + "flagValue": -1 + }, + "expr": { + "active": 0, + "flagValue": -1 + }, + "forin": { + "active": 0, + "flagValue": -1 + }, + "freeze": { + "active": 1, + "flagValue": -1 + }, + "funcscope": { + "active": 0, + "flagValue": -1 + }, + "futurehostile": { + "active": 0, + "flagValue": -1 + }, + "globalstrict": { + "active": 0, + "flagValue": -1 + }, + "immed": { + "active": 0, + "flagValue": -1 + }, + "indent": { + "active": 0, + "flagValue": 4 + }, + "iterator": { + "active": 0, + "flagValue": -1 + }, + "jasmine": { + "active": 0, + "flagValue": -1 + }, + "jquery": { + "active": 1, + "flagValue": -1 + }, + "lastsemic": { + "active": 0, + "flagValue": -1 + }, + "latedef": { + "active": 1, + "flagValue": -1 + }, + "laxbreak": { + "active": 0, + "flagValue": -1 + }, + "laxcomma": { + "active": 0, + "flagValue": -1 + }, + "loopfunc": { + "active": 0, + "flagValue": -1 + }, + "maxcomplexity": { + "active": 0, + "flagValue": 10 + }, + "maxdepth": { + "active": 0, + "flagValue": 3 + }, + "maxlen": { + "active": 0, + "flagValue": 150 + }, + "maxparams": { + "active": 0, + "flagValue": 3 + }, + "maxstatements": { + "active": 0, + "flagValue": 4 + }, + "mocha": { + "active": 0, + "flagValue": -1 + }, + "mootools": { + "active": 0, + "flagValue": -1 + }, + "moz": { + "active": 0, + "flagValue": -1 + }, + "multistr": { + "active": 0, + "flagValue": -1 + }, + "newcap": { + "active": 1, + "flagValue": -1 + }, + "noarg": { + "active": 1, + "flagValue": -1 + }, + "nocomma": { + "active": 0, + "flagValue": -1 + }, + "node": { + "active": 0, + "flagValue": -1 + }, + "noempty": { + "active": 0, + "flagValue": -1 + }, + "nonbsp": { + "active": 0, + "flagValue": -1 + }, + "nonew": { + "active": 1, + "flagValue": -1 + }, + "nonstandard": { + "active": 0, + "flagValue": -1 + }, + "notypeof": { + "active": 1, + "flagValue": -1 + }, + "noyield": { + "active": 0, + "flagValue": -1 + }, + "onecase": { + "active": 0, + "flagValue": -1 + }, + "phantom": { + "active": 0, + "flagValue": -1 + }, + "plusplus": { + "active": 0, + "flagValue": -1 + }, + "proto": { + "active": 0, + "flagValue": -1 + }, + "prototypejs": { + "active": 0, + "flagValue": -1 + }, + "qunit": { + "active": 0, + "flagValue": -1 + }, + "regexp": { + "active": 1, + "flagValue": -1 + }, + "rhino": { + "active": 0, + "flagValue": -1 + }, + "scripturl": { + "active": 0, + "flagValue": -1 + }, + "shadow": { + "active": 0, + "flagValue": -1 + }, + "shelljs": { + "active": 0, + "flagValue": -1 + }, + "singleGroups": { + "active": 0, + "flagValue": -1 + }, + "strict": { + "active": 0, + "flagValue": -1 + }, + "sub": { + "active": 0, + "flagValue": -1 + }, + "supernew": { + "active": 0, + "flagValue": -1 + }, + "typed": { + "active": 0, + "flagValue": -1 + }, + "undef": { + "active": 1, + "flagValue": -1 + }, + "unused": { + "active": 1, + "flagValue": -1 + }, + "varstmt": { + "active": 0, + "flagValue": -1 + }, + "withstmt": { + "active": 0, + "flagValue": -1 + }, + "worker": { + "active": 0, + "flagValue": -1 + }, + "wsh": { + "active": 0, + "flagValue": -1 + }, + "yui": { + "active": 0, + "flagValue": -1 + } + }, + "jsLintFlags2": { + "ass": { + "active": 0, + "flagValue": -1 + }, + "bitwise": { + "active": 0, + "flagValue": -1 + }, + "browser": { + "active": 1, + "flagValue": -1 + }, + "closure": { + "active": 0, + "flagValue": -1 + }, + "continue": { + "active": 0, + "flagValue": -1 + }, + "debug": { + "active": 0, + "flagValue": -1 + }, + "devel": { + "active": 0, + "flagValue": -1 + }, + "eqeq": { + "active": 0, + "flagValue": -1 + }, + "evil": { + "active": 0, + "flagValue": -1 + }, + "forin": { + "active": 0, + "flagValue": -1 + }, + "indent": { + "active": 0, + "flagValue": 4 + }, + "maxlen": { + "active": 0, + "flagValue": 150 + }, + "newcap": { + "active": 0, + "flagValue": -1 + }, + "node": { + "active": 0, + "flagValue": -1 + }, + "nomen": { + "active": 0, + "flagValue": -1 + }, + "plusplus": { + "active": 0, + "flagValue": -1 + }, + "properties": { + "active": 0, + "flagValue": -1 + }, + "regexp": { + "active": 0, + "flagValue": -1 + }, + "rhino": { + "active": 0, + "flagValue": -1 + }, + "sloppy": { + "active": 0, + "flagValue": -1 + }, + "stupid": { + "active": 0, + "flagValue": -1 + }, + "sub": { + "active": 0, + "flagValue": -1 + }, + "todo": { + "active": 0, + "flagValue": -1 + }, + "unparam": { + "active": 0, + "flagValue": -1 + }, + "vars": { + "active": 0, + "flagValue": -1 + }, + "white": { + "active": 0, + "flagValue": -1 + } + }, + "jsonAutoOutputPathEnabled": 0, + "jsonAutoOutputPathFilenamePattern": "*-min.json", + "jsonAutoOutputPathRelativePath": "", + "jsonAutoOutputPathReplace1": "", + "jsonAutoOutputPathReplace2": "", + "jsonAutoOutputPathStyle": 0, + "jsonOrderOutput": 0, + "jsonOutputStyle": 1, + "kitAutoOutputPathEnabled": 1, + "kitAutoOutputPathFilenamePattern": "*.html", + "kitAutoOutputPathRelativePath": "", + "kitAutoOutputPathReplace1": "", + "kitAutoOutputPathReplace2": "", + "kitAutoOutputPathStyle": 0, + "lessAllowInsecureImports": 0, + "lessAutoOutputPathEnabled": 1, + "lessAutoOutputPathFilenamePattern": "*.css", + "lessAutoOutputPathRelativePath": "..\/css", + "lessAutoOutputPathReplace1": "less", + "lessAutoOutputPathReplace2": "css", + "lessAutoOutputPathStyle": 2, + "lessCreateSourceMap": 0, + "lessDisableJavascript": 0, + "lessIeCompatibility": 1, + "lessOutputStyle": 0, + "lessRelativeURLS": 0, + "lessStrictImports": 0, + "lessStrictMath": 0, + "lessStrictUnits": 0, + "markdownAutoOutputPathEnabled": 1, + "markdownAutoOutputPathFilenamePattern": "*.html", + "markdownAutoOutputPathRelativePath": "", + "markdownAutoOutputPathReplace1": "", + "markdownAutoOutputPathReplace2": "", + "markdownAutoOutputPathStyle": 0, + "markdownCriticStyle": 0, + "markdownEnableFootnotes": 1, + "markdownEnableLabels": 1, + "markdownEnableSmartQuotes": 1, + "markdownEscapeLineBreaks": 0, + "markdownMaskEmailAddresses": 1, + "markdownOutputFormat": 0, + "markdownOutputStyle": 0, + "markdownParseMetadata": 1, + "markdownProcessHTML": 0, + "markdownRandomFootnoteNumbers": 0, + "markdownUseCompatibilityMode": 0, + "reloadFileURLs": 0, + "sassAutoOutputPathEnabled": 1, + "sassAutoOutputPathFilenamePattern": "*.css", + "sassAutoOutputPathRelativePath": "..\/css", + "sassAutoOutputPathReplace1": "sass", + "sassAutoOutputPathReplace2": "css", + "sassAutoOutputPathStyle": 2, + "sassCreateSourceMap": 0, + "sassDebugStyle": 0, + "sassDecimalPrecision": 10, + "sassOutputStyle": 0, + "sassUseLibsass": 0, + "shouldRunAutoprefixer": 0, + "shouldRunBless": 0, + "skippedItemsString": ".svn, .git, .hg, log, _logs, _cache, cache, logs, node_modules", + "slimAutoOutputPathEnabled": 1, + "slimAutoOutputPathFilenamePattern": "*.html", + "slimAutoOutputPathRelativePath": "", + "slimAutoOutputPathReplace1": "", + "slimAutoOutputPathReplace2": "", + "slimAutoOutputPathStyle": 0, + "slimCompileOnly": 0, + "slimLogicless": 0, + "slimOutputFormat": 0, + "slimOutputStyle": 1, + "slimRailsCompatible": 0, + "stylusAutoOutputPathEnabled": 1, + "stylusAutoOutputPathFilenamePattern": "*.css", + "stylusAutoOutputPathRelativePath": "..\/css", + "stylusAutoOutputPathReplace1": "stylus", + "stylusAutoOutputPathReplace2": "css", + "stylusAutoOutputPathStyle": 2, + "stylusCreateSourceMap": 0, + "stylusDebugStyle": 0, + "stylusImportCSS": 0, + "stylusOutputStyle": 0, + "stylusResolveRelativeURLS": 0, + "typescriptAutoOutputPathEnabled": 1, + "typescriptAutoOutputPathFilenamePattern": "*.js", + "typescriptAutoOutputPathRelativePath": "\/js", + "typescriptAutoOutputPathReplace1": "", + "typescriptAutoOutputPathReplace2": "", + "typescriptAutoOutputPathStyle": 2, + "typescriptCreateDeclarationFile": 0, + "typescriptCreateSourceMap": 0, + "typescriptMinifyOutput": 0, + "typescriptModuleType": 0, + "typescriptNoImplicitAny": 0, + "typescriptPreserveConstEnums": 0, + "typescriptRemoveComments": 0, + "typescriptSuppressImplicitAnyIndexErrors": 0, + "typescriptTargetECMAVersion": 0, + "uglifyDefinesString": "", + "uglifyFlags2": { + "ascii-only": { + "active": 0, + "flagValue": -1 + }, + "bare-returns": { + "active": 0, + "flagValue": -1 + }, + "booleans": { + "active": 1, + "flagValue": -1 + }, + "bracketize": { + "active": 0, + "flagValue": -1 + }, + "cascade": { + "active": 1, + "flagValue": -1 + }, + "comments": { + "active": 1, + "flagValue": -1 + }, + "comparisons": { + "active": 1, + "flagValue": -1 + }, + "compress": { + "active": 1, + "flagValue": -1 + }, + "conditionals": { + "active": 1, + "flagValue": -1 + }, + "dead_code": { + "active": 0, + "flagValue": -1 + }, + "drop_console": { + "active": 0, + "flagValue": -1 + }, + "drop_debugger": { + "active": 1, + "flagValue": -1 + }, + "eval": { + "active": 0, + "flagValue": -1 + }, + "evaluate": { + "active": 1, + "flagValue": -1 + }, + "hoist_funs": { + "active": 1, + "flagValue": -1 + }, + "hoist_vars": { + "active": 0, + "flagValue": -1 + }, + "if_return": { + "active": 1, + "flagValue": -1 + }, + "indent-level": { + "active": 0, + "flagValue": 4 + }, + "indent-start": { + "active": 0, + "flagValue": 0 + }, + "inline-script": { + "active": 0, + "flagValue": -1 + }, + "join_vars": { + "active": 1, + "flagValue": -1 + }, + "keep_fargs": { + "active": 0, + "flagValue": -1 + }, + "keep_fnames": { + "active": 0, + "flagValue": -1 + }, + "loops": { + "active": 1, + "flagValue": -1 + }, + "mangle": { + "active": 1, + "flagValue": -1 + }, + "max-line-len": { + "active": 1, + "flagValue": 32000 + }, + "negate_iife": { + "active": 1, + "flagValue": -1 + }, + "properties": { + "active": 1, + "flagValue": -1 + }, + "pure_getters": { + "active": 0, + "flagValue": -1 + }, + "quote-keys": { + "active": 0, + "flagValue": -1 + }, + "screw-ie8": { + "active": 0, + "flagValue": -1 + }, + "semicolons": { + "active": 1, + "flagValue": -1 + }, + "sequences": { + "active": 1, + "flagValue": -1 + }, + "sort": { + "active": 0, + "flagValue": -1 + }, + "space-colon": { + "active": 1, + "flagValue": -1 + }, + "toplevel": { + "active": 0, + "flagValue": -1 + }, + "unsafe": { + "active": 0, + "flagValue": -1 + }, + "unused": { + "active": 0, + "flagValue": -1 + }, + "warnings": { + "active": 0, + "flagValue": -1 + }, + "width": { + "active": 1, + "flagValue": 80 + } + }, + "uglifyReservedNamesString": "$", + "websiteRelativeRoot": "" + }, +"settingsFileVersion": "2" +} \ No newline at end of file diff --git a/library/admin b/library/admin new file mode 160000 index 00000000..25ad8c26 --- /dev/null +++ b/library/admin @@ -0,0 +1 @@ +Subproject commit 25ad8c26f459595b03e9b8c84c363d770681dc63 diff --git a/library/admin/.gitignore b/library/admin/.gitignore deleted file mode 100644 index b393926d..00000000 --- a/library/admin/.gitignore +++ /dev/null @@ -1,26 +0,0 @@ -# Editors -project.xml -project.properties -/nbproject/private/ -.buildpath -.project -.settings* -sftp-config.json -codekit-config.json -.idea - -# Grunt -md5 -/docs/ -/redux/ -/output/ -/node_modules/ -/grunt-phplint/ -/tmp-wp-dev/ -npm-debug.log - -# OS X metadata -.DS_Store - -# Windows junk -Thumbs.db diff --git a/library/admin/.jshintrc b/library/admin/.jshintrc deleted file mode 100644 index d8e6cb82..00000000 --- a/library/admin/.jshintrc +++ /dev/null @@ -1,19 +0,0 @@ -{ - "boss": true, - "immed": true, - "noarg": true, - "onevar": true, - - "browser": true, - - "globals": { - "_": false, - "jQuery": true, - "module": true, - "console": true, - "document": true, - "window": true, - "redux_change": true, - "redux": true - } -} diff --git a/library/admin/.travis.yml b/library/admin/.travis.yml deleted file mode 100644 index 35a95ec3..00000000 --- a/library/admin/.travis.yml +++ /dev/null @@ -1,54 +0,0 @@ -language: php -php: -#- 5.2 -- 5.3 -#- 5.4 -env: - global: - #secure: "HxNuZO2wWngETP4ZAJN/IA4SCG9C3yw8hV4laJOrb9xXRv8w1YI4xLKUTDEK8H1tg3f0Yh4943f22aDPoXUu8oG913yljbrjMPXM+30FkbxPLOu4rViepjV1ZPJ0+aw+fGvNfDWBfeNx32Ooi9BeK5cpGTKeLgzAJCeG2mROPpo=" - #secure: "vLqv9UpmPontcizx0ncbiaV0CJ6C54sFcJw1g4Csnwz7q3DJyHtGtjZLysKzyUzbXLzcSGWZfkeqbYXIuI7fdtIfBTSb9Zw39tPDItVzq9T+wyzkCv98F+LI4Py2UJR+dQNOzB+2s0IrAQZt3vsKnJbELKwQ1LWVkNXOu7eCIOo=" - #secure: "N1TGV9fQSoXhWD0AUMLF4PEWE99ZHA3ypjARJZX3fsycRD4YUbCcIdnKld5rM/4meeVN4kULDci5bcwAv3GrZY0l4lYNFpnInoyOU6B8PFG0795feacUtj8T8GBs9C4P/9ikLkK9BBXEacQ+i/E2Lvv50QJ17RDAbmvXB3gWDvc=" - #secure: "qZjPMjuQN2a4H2fQ9SSSfgAYRIoRmSTOxMF06CjeTQfIgimwmCayQYVVSKrXQorxpzHPjjg4vEs92oFuBE2nXDN0J4fA8u/E3Qvm4Mr9qWFn/JoOX+/xsYurPw9+rIjr75lT/b8cK38tdgqm7TmMIfsNY4RxHtOhXjt6hWGhUlY=" - secure: "aDIYEmgxoF/+2vwPdvmbxFKMoz8pA9vtvemehyLNvH3LF05RgFiwNNv+7Lvy127p4Fxp3VBK+ZLKUEEL1gdpevzgni9EigpK8YZbIVHXRL3U+1eP9rcnjuGF9pKuB4kB2ivzoprcalg1ZDI9PnRYRDE4YUTHJiEN2MmLys1QWdc=" - cache: - directories: - - node_modules - matrix: - - WP_VERSION=latest WP_MULTISITE=0 - - WP_VERSION=latest WP_MULTISITE=1 -install: -- npm install -g grunt-cli -- npm install -- find ReduxCore -type f | sort -u | xargs cat | md5sum > md5 -before_script: bash bin/install-wp-tests.sh wordpress_test root '' localhost $WP_VERSION -script: -- phpunit -- grunt jshint -- grunt lintPHP -after_success: - # Install the Heroku gem (or the Heroku toolbelt) - - gem install heroku - # Add your Heroku git repo: - - git remote add heroku git@heroku.com:redux-premium.git - # Turn off warnings about SSH keys: - - echo "Host heroku.com" >> ~/.ssh/config - - echo " StrictHostKeyChecking no" >> ~/.ssh/config - - echo " CheckHostIP no" >> ~/.ssh/config - - echo " UserKnownHostsFile=/dev/null" >> ~/.ssh/config - # Clear your current Heroku SSH keys: - - heroku keys:clear - # Add a new SSH key to Heroku - - yes | heroku keys:add -after_script: - #- ./bin/commit-uncompressed-files.sh - - ./bin/update-mirrors-docs.sh -notifications: - email: - recipients: - - support@redux.io - on_failure: always - slack: redux:79L14EG4ktCO8P24yKa8le4s -branches: - except: - - gh-pages - - setup diff --git a/library/admin/.tx/config b/library/admin/.tx/config deleted file mode 100644 index 71fa6def..00000000 --- a/library/admin/.tx/config +++ /dev/null @@ -1,8 +0,0 @@ -[main] -host = https://www.transifex.com - -[redux-framework.redux-framework] -file_filter = ReduxCore/languages/.po -source_file = ReduxCore/languages/redux-framework.pot -source_lang = en_US -type = PO diff --git a/library/admin/CHANGELOG.md b/library/admin/CHANGELOG.md deleted file mode 100644 index 9831c2b6..00000000 --- a/library/admin/CHANGELOG.md +++ /dev/null @@ -1,1791 +0,0 @@ -# Redux Framework Changelog - -## 3.5.6.4 -* Added: `ajax_save` arg for fields. Setting to false will reload the options panel when the set option has changed. -* Fixed: #2532 - Spinner field arrow spacing off when dev_mode set to false due to missing `!important` CSS suffix. - -## 3.5.6.3 -* Added: `autocomplete` arg to text field. This is FALSE by default. - -## 3.5.6.2 -* Fixed: Color RGBA field missing name_suffix. Will now work in repeater extension. - -## 3.5.6.1 -* Fixed: Index error regarding icon argument. - -## 3.5.6 -* Fixed Customizer WP 4.3 final fixes. - -## 3.5.5.9 -* Fixed #2500 - Conflict with outdated select2 in JW Player plugin. - -## 3.5.5.8 -* Modified: icon_type no longer needed for section icons. Now detects if URLs are provided for images. -* Fixed: Various customizer fixes. HTML in the customizer title. -* Modified: Media URL now is 95% wide. -* Modified: Select2 now 100% width instead of just resolve (that doesn't always work). - -## 3.5.5.7 -* Modified: Field enqueue method to allow for more flexibility. -* Added: Support for Airplane Mode plugin (https://github.com/norcross/airplane-mode) by @norcross. Thanks @chriscct7 #2463 - -## 3.5.5.6 -* Fixed: Undefined index in theme-check enhancements. Thanks @winwinwebdesign! -* Removed: SASS compiler & code. Note needed. -* Fixed: Color transparency live-update for Customizer for color, background, - and color gradient fields. - -## 3.5.5.5 -* Fixed: Undefined index when removing a section. - -## 3.5.5.4 -* Fixed: Typography bug onload always saying settings have changed. -* Modified: Added minified customizer JS. - -## 3.5.5.3 -* Fixed: Redux CUSTOMIZER! YEA! - -## 3.5.5.2 -* Fixed: Small echo in Redux API - -## 3.5.5.1 -* Fixed: PHP 5.2 Theme-Check error. - -## 3.5.5 -* Fixed: Date-time fixes with CSS overloading and positioning. - -## 3.5.4.35 -* Added: Lite support for https://wordpress.org/plugins/plugin-dependencies/ -* Modified: CDN to be a more bulletproof solution (http://jsdelivr.net). -* Modified: CDN alerts to be more clear, and have proper links. - -## 3.5.4.34 -* Fixed: Bad code in raw field hosing up the entire panel. - -## 3.5.4.33 -* Modified: #2436 - Validation check for any validation type ending in 'not_empty' now recognized. - -## 3.5.4.32 -* Fixed: Undefined index for undeclared variable in Theme-Check checks. -* Fixed: Annoying Redux Theme-Check notices. -* Fixed: How some functions were called. - -## 3.5.4.31 -* Fixed: Theme-Check baby! Everything working as it should with extra theme-check hints to prepare - your theme for submission! -* Fixed: Better .org hinting for theme submission. -* Modified: `forced_dev_mode_off` argument that will ensure dev_mode is ALWAYS off. - PLEASE do not ship with this enabled. We will NOT provide any support for any instance that - has this argument enabled. Disable and test prior to posting on our issue tracker. -* Added: `customizer_only` as a global arg that disables all of Redux except for the customizer, in - preparation for our customizer integration. - -## 3.5.4.30 -* Modified: Dissmissable Redux Admin notices now use the WP 4.2 dismiss JS and Ajax. Pretty. -* Modified: Admin notice code is now it's own isolated class inside core. -* Modified: Use DB for admin notice, not flat-files. Boo. -* Modified: Sample configs not to cause errors if multiple users use the same function name. -* Fixed: CDN internationalization class. -* Modified: Parsedown so as not to throw a shortcode error that didn't actually exist. - -## 3.5.4.29 -* Fixed: #2446 - Non google font choice not saving in certain instances. - -## 3.5.4.28 -* Fixed: Added additional check in redux.js to stop errors with panels containing multiple raw fields. -* Fixed: Hopefully, the issue of settings not saving on first install when using the Redux API. - -## 3.5.4.27 -* Fixed: Set use_cdn argument to true, by default. - -## 3.5.4.26 -* Fixed #2437 - undefined value set to blank line height. - -## 3.5.4.25 -* Fixed: #2429 - Required evaluator 'contains' not working properly with multi_check - -## 3.5.4.24 -* Fixed: #2426 - Section field not indenting. - -## 3.5.4.23 -* Fixed: Divider field not rendering properly. -* Added: `fieldset_class` argument for fields. Thanks @Enchiridion. -* Added: Option to set checkbox label. Thanks @Enchiridion. -* Added: javascript .trigger('change') to switch, spinner, and image_select. Thanks @Enchiridion. - -## 3.5.4.22 -* Modified: Ajax change output of error and notice via hooks. - -## 3.5.4.21 -* Fixed: #2414 - Bad ajax save due to mis-initialized variable. - -## 3.5.4.20 -* Fixed: CSS in metabox fields all wanky. -* Added: 'reload_on_change' arg for fields, to force page reload after setting change. - -## 3.5.4.19 -* Fixed: #2377 - Replaced mysql_gets_server_info with $wpdb. - -## 3.5.4.18 -* Modified: Templates to properly excape values. -* Fixed: Import/Export to properly be full-width and use lazy-load JS. -* Modified: CSS for sections to bound to the section, not all of Redux. - -## 3.5.4.17 -* Fixed: #2368 - Options panel layout offset. -* Fixed: #2369 - validate_callback not working for color, color_gradient, and date. - -## 3.5.4.16 -* Fixed: #2355 - Space missing in switch class arg. -* Fixed: Fixed all fields without leading space in class arg. - -## 3.5.4.15 -* Modified: Restrict table modification to redux-container. -* Fixed: Container overflow for pre's. -* Modified: Redux API to include removeSection and removeField. -* Added: Added before and after hooks to any panel template file. - -## 3.5.4.14 -* Fixed: #2351 - WP_Error check added to admin blast remote get. - -## 3.5.4.13 -* Modified: Moved styling for the divide field into it's own CSS file. -* Modified: All WP Color Pickers to properly save the value before save. -* Added: CSS Styles for the customizer. ;) - -## 3.5.4.12 -* Modified: Panel is MUCH more responsive now. -* Fixed: Small stylings for a few fields. -* Fixed: Added extra qTip class. - -## 3.5.4.11 -* Modified: Ajax save animation. Added fallback for pre 4.2 CSS. -* Fixed: Small issue with Redux info boxes and spacing. -* Fixed: Small bug with the Redux API where divide sections were causing errors. -* Fixed: Small admin blast fix. - -## 3.5.4.10 -* Modified: Qtip and Spectrum vendor libraries restored to local. -* Fixed: Admin notice loading on front end. -* Modified: Callback actions run with do_action_ref_array now. -* Added: show_options_object argument to enable or disable option object. - -## 3.5.4.9 -* Added: Error suppressing to filesystem class to avoid notice errors when site goes down. - -## 3.5.4.8 -* Fixed: Panels not rendering, again -* Added: Vendor support plugin link to CDN fallback message. - -## 3.5.4.7 -* Modified: Moved vendor libraries ACE, select2, qtip, and spectrum to CDN. -* Removed: Local installs of above libraries. - -## 3.5.4.6 -* Fixed: Option panel not rendering due to experimental code. - -## 3.5.4.5 -* Fixed: How sorter works with data -* Modified: How the data arg is stored in Redux. - -## 3.5.4.4 -* Removed: sysinfo.php. No longer needed in lieu of our support URL feature. -* Removed: debug.php. Moved to options_object extension. -* Modified: #2274 - PHP Unit test compatibility. Thanks @daithi-coombes. -* Modified: #2144 - Optional class argument per image. Thanks @paulthecoder. -* Fixed: #2278 - More W3 Total Cache hacks. - -## 3.5.4.3 -* Fixed: #2258 - welcome redirect error with embedding plugin scenarios. -* Fixed: Redux plugin load order when activating plugins. - -## 3.5.4.2 -* Fixed: #2271 - stuck redirect on godaddy (seriously, get a real host, people) servers. - -## 3.5.4.1 -* Fixed: #2216 - Reset section not always working within FF. - -## 3.5.4 -* Modified: update_notice arg only truly shows up if dev_mode is on. - -## 3.5.3.3 -* Added: Tooltip to developer mode badge, for informational purposes. -* Modified: Added css_layout ext to default value filter, to avoid errors. - -## 3.5.3.2 -* Fixed: #2239 - Various extensions didn't support default values for default arg. Filtered out offending extensions. - -## 3.5.3.1 -* Fixed: WP.org ONLY SVN mixup. - -## 3.5.3 -* Fixed: #2228 - Submenu items still visible if permissions not allowed. -* Fixed: Import/Export showing up in customizer. -* Modified: Admin-fresh theme to match new WordPress 4.2 -* Modified: Redux widget now has a proper ID. Thanks @corradomatt! -* Modified: Added text-shadow to submenu items to give a stronger "pop" -* Modified: Page_slug now dynamically generated if not specified. - -## 3.5.2.2 -* Modified: Admin blast message pinging server on each load after three day expiration. Possible slow down of the overall panel loading time. - -## 3.5.2.1 -* Fixed: #2221 - Background field media not enqueueing when used with no other media based fields. - -## 3.5.2 -* Fixed: #2214: Bad path for import/export enqueue. -* Release: Wp.org release. - -## 3.5.1 -* Release: Wp.org release. - -## 3.5.0.7 -* Modified: Redux News dashboard widget appears only when dev_mode is true or in a local host environment. - -## 3.5.0.6 -* Fixed #2127 - Elusive icons not working in footer as before. -* Fixed Issue where Status tab not showing extension versions properly. -* Fixed Issue in support URL not passing data correctly. - -## 3.5.0.5 -* Fixed Support URLs now work even if max_input_vars is way low in PHP 5.3+ - -## 3.5.0.4 -* Fixed #2197 - Import/export not loading proper for those who have opted to install Wordpress in ways it was never intended. - -## 3.5.0.3 -* Fixed: 'Generate Support URL' feature kicking back error. - -## 3.5.0.2 -* Fixed Sortable checkbox labels not displaying properly. -* Fixed Sortable textbox not displaying default value as placeholder. -* Updated: sample-config with accurate example for both sortable modes. - -## 3.5.0.1 -* Fixed #2181 - Fixed issue with Ajax Save when PHP 5.3 Magic Quotes were disabled. - -## 3.5.0 OFFICIAL RELEASE - Various fixes and improvements for release. - -## 3.4.4.9.4 -* Fixed: #2181 - Issue with PHP < 5.4 and the Ace Editor field. Oy. - -## 3.4.4.9.3 -* Fixed: #2163 - Undefined error in JS. - -## 3.4.4.9.2 -* Fixed: #2176 - Infinite loop in the customizer for live preview of themes. - -## 3.4.4.9.1 -* Fixed: Support page now works. -* Fixed: Fix for MySQL deprecated functions in php 5.5+. - -## 3.4.4.9 -* Added: Dynamic admin messages (aka Newsflash). Dismissable admin messages announcing breaking Redux news. - Messages will not appear for users when dev_mode is set to `false`. However, messages remain active - on localhosts, so devs may benefit. - -## 3.4.4.8 -* Fixed: #2155 - Fixed import with ajax_save. -* Fixed: Changelog now uses raw field parsedown if present. - -## 3.4.4.7 -* Added: Redux Framework News Widget on the WP Dashboard. - -## 3.4.4.6 -* Fixed: #2156: `label` argument not recognized when using sortable as textbox. - -## 3.4.4.5 -* Fixed: #2140 Another PHP 5.2 issue with ajax_save. -* Modified: Opt groups for select field now working in customizer even if not supported. - -## 3.4.4.4 -* Added: `full_width` arg now makes ANY field full-width. :) - -## 3.4.4.3 -* Fixed: #2133 - Ajax save adding extra backspashes in PHP 5.2 only (They didn't use array map properly). -* Fixed: Customizer wasn't working. Thanks @sgssandhu! - -## 3.4.4.2 -* Fixed: #2125 - Compiler not firing on first save, when using ajax_save. - -## 3.4.4.1 -* Fixed: #2118 - Typography JS error. - -## 3.4.4 -* Fixed: Odd typography bug no one has reported. -* Modified: Sticky header and footer to remain within the redux-main container. - -## 3.4.3.9 -* Fixed #2097 - Slash fix for ajax_save that was previously believed to be an isolated issue. Now applied on all ajax saves. - -## 3.4.3.8 -* Fixed: #2086 - color_rgba improperly functioning when transparent mode set to false. - -## 3.4.3.7 -* Fixed Import/Export bug where it wasn't running. -* Modified Locations of the core extensions directory as well as grunt configuration. - -## 3.4.3.6 -* Fixed #2047 - Validation will now accept 0 as a value to be tested. Thanks @Ninos! -* Added url_slug validation with option flush_permalinks! -* Fixed Issue where the remove of background field was always showing an empty preview box. -* Modified Turned ajax_save on by default for additional bug reports. ;) -* Modified Added some margin above validation errors/warnings so they look better. -* Modified Removed previous element border for any section so it looks better. - -## 3.4.3.5 -* Fixed #2081 - Section field hiding any field after. Weird. - -## 3.4.3.4 -* Added #2047 - `output_transparent` argument to output the blank color feature as 'transparent'. -* Fixed #2080 - missing 'rem' unit and inability to process float values. Thanks to @HELWATANY for the fixes! -* Fixed #2043 - misaligned images in image_select field. - -## 3.4.3.3 -* Added: #2064 - Merge argument for image_select. Thanks @Ninos -* Modified: Import/Export is now an extensiona and decoupled from the core. -* Fixed: Spinner had a nasty number bug, now resolved. -* Fixed: #2076 - RTL bug with old ID's. Thanks @mahfoozroy. -* Fixed: #2072 - Ajax_save editor type bug fix. - -## 3.4.3.2 -* Fixed: #2058 - Incorrect path in include statement for sysinfo.php - -## 3.4.3.1 -* Modified: Templates now have versioning with a warning (dev_mode only) if they are outdated from the core templates. - -## 3.4.3 -* Modified: Ajax saving now has overlay during save to avoid confusion for users. - -## 3.4.2.9 -* Modified: Template files even more for simplicity and ease. -* Modified: Saving. Redux now has the ajax_save argument if you want it! -* Modified: Validation warnings now work. - -## 3.4.2.8 -* Fixed: Changed set_transient function to public to avoid errors in new templating code. - -## 3.4.2.7 -* Modified: Entire panel template is now decoupled from the theme and implemented with many filters for easy customization. - -## 3.4.2.6 -* Fixed: #1478 - Import/export failing when two instances if Redux in use. Thanks, @desaiuditd! -* Fixed: Section field not indenting properly, if at all. - -## 3.4.2.5 -* Added: #2031 - Proper CSS sanitization for compliancy with WP.org. - -## 3.4.2.4 -* Fixed: #2027 - added isset() - -## 3.4.2.3 -* Fixed: #2019 - Reset issues with PHP 5.2. Thanks a bunch, @Webcreations907! - -## 3.4.2.2 -* Fixed: #2023: Issue with custom submenus in menu. - -## 3.4.2.1 -* Fixed: #2025: Issue with select sorting. - -## 3.4.2 -* Update: ACE Editor. Thanks @corradomatt. - -## 3.4.1 -* Fixed: Small filesystem option with bad filter key reference. -* Added: Small return if $section filter returned the section empty. - -## 3.4.0 -* WP.org Release - -## 3.3.10.7 -* Fixed: Reset section hook firing too early. - -## 3.3.10.6 -* Modified: The Redux Repeater field has landed! - -## 3.3.10.5 -* Fixed: #1983 - color_rgba not outputting default values on first load (before save). - -## 3.3.10.4 -* Fixed: Google font enqueues with opt_name to avoid collision with multiple Redux instances. - -## 3.3.10.3 -* Fixed: #1980 - JS errors with sorter & sortable. -* Fixed: color_rgba field outputting incorrect information via output/compiler. - -## 3.3.10.2 -* Fixed: #1979 - Goole fonts not properly loading in typography dropdown. - -## 3.3.10.1 -* Fixed: Undefined index error on MU installs. - -## 3.3.10 -* Removed: SASS compile of field CSS, for the time being. Compiler remains in core. -* Improved: Panel load time, most notable when not in dev_mode. Better for your clients. :) -* Updated: Elusive Font library. -* Fixed: #1961 - color_rgba field defaulting to black on reset. - -## 3.3.9.35 -* Fixed: #1941 - Datepicker opened off screen. -* Fixed: #1756, #1957 - Slider issues. Thanks @FFIN! -* Fixed: #1960 - Duplicate slide when clicking Add. Again, thanks to @FFIN for the fix. -* Added: New filter: apply_filters 'redux/validate/{opt_name}/before_validation' -* Fixed: #1745 - Adding settings submenu to empty submenu now works. Many, many thanks to @No3x for cracking this one! - -## 3.3.9.34 -* Fixed: #1955 - Undefined index rgba in output routine. - -## 3.3.9.33 -* Modified: #1947 - Added display:none to TR tag under info field. - -## 3.3.9.32 -* Replaced: #1951 - Replaced develop branch of scssphp to master branch due to PHP 5.2 incompatibililty. - -## 3.3.9.31 -* Fixed: #1943 - Removed premature DIV close. -* Fixed: #1945 - Media preview not rendering when default ID specified. - -## 3.3.9.30 -* Modified: #1930 - reorder 'psedo-class of link_color field. Thanks @freddessaint -* Modified: SASS compiler outputs to page by default. Faster. -* Fixed: #1927 - Incorrect dir path to spectrum library in color_rgba field corrected. - -## 3.3.9.29 -* Modified: color_rgba field now usees spectrum color picker. minicolors removed. Just...too buggy. - -## 3.3.9.28 -* Modified: #1922 - Filesystem output function. - -## 3.3.9.27 -* Fixed: Added PHP 5.2 support (ugh!) for SASS compiler. - -## 3.3.9.26 -* Fixed: More SASS compiler tweaking. - -## 3.3.9.25 -* Fixed: PHP errors when disabling SASS. - -## 3.3.9.24 -* Fixed #1909 - malformed DIV class HTML in slider field. - -## 3.3.9.23 -* Removed Argument for SASS compile file output location removed. Didn't work, too much trouble. - -## 3.3.9.22 -* Fixed: #1904 - select_image field not displaying saved value on page reload. - -## 3.3.9.21 -* Fixed: SASS compile under multi-instance outputting incorrect CSS file - -## 3.3.9.20 -* Fixed: redux-admin scss images converted to base64 - -## 3.3.9.17 -* Added SASS compiler for admin CSS. -* Added SASS to CSS for grunt compiler. - -## 3.3.9.16 -* Added SASS compiler for fields. - -## 3.3.9.16 -* Updated: select2 3.5.2 - -## 3.3.9.15 -* Fixed: #1856 - Illegal offset string warnings in framework.php. Thanks @CGlingener. -* Fixed: #1874 - Required operator 'contains' and 'not_contains' not working with select set to multi. -* Fixed: #1829 - Required operator '=' and '!=' not working with select set to multi. - -## 3.3.9.14 -* Fixed: #1870 - Border field doubling up on px in output/compiler. -* Added: `hidden` argument for fields. -* Added: `hidden` argument for sections. - -## 3.3.9.12 -* Fixed: #1868 - Improper panel render when opening expanded, when `open_expanded` set to true. -* Added: `hide_expand` argument, to hide the expand options button. - -## 3.3.9.11 -* Fixed: #1865 - Sortable select not saving proper order. -* Fixed: #1864 - Footer z-index CSS adjusted. - -## 3.3.9.10 -* Fixed: #1848 - Import-export filed buttons not functioning properly. - -## 3.3.9.9 -* Fixed: #1834 - Wordpress data dealing with IDs as array keys not rendering properly. -* Fixed: #1830 - Font lists were added in quotes. Thanks @karimhossenbux. - -## 3.3.9.8 -* Fixed: #1798 - Fixed lazy load JS to only load visible sections. Much more optimized. - -## 3.3.9.7 -* Fixed: #1821 - Exo 2 font not working, issue with typography and escaping. - -## 3.3.9.6 -* Added: #1803 - Optgroup support for select field. - -## 3.3.9.5 -* Added: Decimal increments to spinner. - -## 3.3.9.4 -* Added: Customizer now supports PANEL! Yay 4.0. - -## 3.3.9.3 -* Fixed: #1789 - Customizer now properly working again with WP 4.0. Odd bug. -* Modified: README.md updates as per @cmwwebfx suggestions. - -## 3.3.9.2 -* Fixed: #1782 - Fixed some extra themecheck and customizer issues. - -## 3.3.9.1 -* Fixed: #1782 - Media field not showing files after upload? Hopefully this fixes it. - -## 3.3.9 -* Fixed: #1775 - Call to undefined function is_customize_preview() in pre WP 4.0. -* Fixed: Issue where in some cases tracking still occuring after opt-out. -* Modified: Documentation URL. - -## 3.3.8.8 -* Fixed: #1742 - Sidebar subsections don't always expand. - -## 3.3.8.7 -* Fixed: #1758 - Thanks @echo1consulting! -* Added: 'hidden' to menu_type argument to allow for hidden menus until available. - -## 3.3.8.6 -* Fixed: #1749 - Remove font-wight and font-style from css output when not in use. - -## 3.3.8.5 -* Modified: Added the "redux/options/{$this->args['opt_name']}/compiler/advanced" hook for more advanced compiling. -* Added: Suggestions as per #1709. Thanks @echo1consulting. - -## 3.3.8.4 -* Modified: Removed a cURL instance from the core and fixed the developer ad resizing. -* Fixed: PHP 5.2 issues. *sigh* - -## 3.3.8.3 -* Added: #1593 - Great pull request by @JonasDoebertin. Now you can enqueue dynamic output to the login screen or admin backend. - -## 3.3.8.2 -* Fixed: Customizer wasn't saving at all! That's been like 4 months. No one's reported it. Hmm. -* Fixed: #1702 - Customizer only fields were being erased on panel save. - -## 3.3.8.1 -* Fixed: Various Theme-Check errors with languages. -* Added: Theme-Check class to help devs know what is what. -* Fixed: The way we include files from include_once to require_once everywhere. -* Modified: Language files to reflect new strings. -* Modified: Formatted a bunch of old class files. -* Added: Notice on the updates for non-devs to use the new dev_mode disabler plugin and notify their developer. ;) - -## 3.3.8 -* Modified: Updated potomo, thanks @shivapoudel. -* Added: Grunt checktextdomain and made improvements. Thanks @shivapoudel. - -## 3.3.7.11 -* Modified: #1685 - Specifying no default argument for image_select caused errors on reset. - -## 3.3.7.10 -* Fixed: #1667 - Slides Upload button causing JS error. - -## 3.3.7.9 -* Fixed: #1670 - Fix for Theme Check -> `add_setting() method needs to have a sanitization callback function passed.` - -## 3.3.7.8 -* Fixed: #1661 - Fix for undefined index in some versions of PHP. Thanks @gianbalex! -* Modified: #1658 - Improvements from @shivapoudel, including: - * Removed makepot and used grunt-wp-i18n instead. - * Added a jshintrc file - * Added a `grunt addtextdomain` to correct any bad textdomains in the core. - * Updated .gitignore for better readability - * Updates to a few other files including package.json. - * Updated language files. - * Update codestyles/.editorconfig to reflect the project's standards. - -## 3.3.7.7 -* Modified: #1653 - Better admin bar with external links: Admin bar menu priority, icon, and external links. Thanks @shivapoudel! - -## 3.3.7.6 -* Added: #1651 - `library_filter` argument. Allows specification of what files to display in the media library. -* Modified: #1651 - `mode` argument accepts either file type or mime type (but not both). - -## 3.3.7.5 -* Fixed: #1650 - Toogle error with responsive CSS. - -## 3.3.7.4 -* Fixed: #1643 - Slight border issue (2px) on sticky footer. - -## 3.3.7.3 -* Fixed: #1642 - Added `font_family_clear` arg, enabling the clear option for font-family. -* Fixed: #1638 - Spacing field not outputting when units values attached to default values. -* Modified #1644 - `import_icon` argument now accepts wordpress dashicons - -## 3.3.7.2 -* Fixed: #1634 - Double border for sections field. Thanks @AlexandruDoda -* Modified: Changelog location to now Changelog.md. - -## 3.3.7.1 -* Fixed: #1632 - Sortable with no defaults set revert to false (instead of options values). -* Fixed: Labels for sortable in text mode updated to match framework. - -## 3.3.7 -* Added: #1586 - Class-level declaration for callbacks and validation. Thanks @echo1consulting. -* Modified: Typography field now fully dynamic. -* Modified: No longer require a google_api_key for the typography module. :) -* Fixed: FTP credentials screen giving a "undefined submit_button function". Resolved. -* Modified: #1628 - Spacing and dimensions now only output 0 if the entry is a 0, not empty. - Thanks @Webcreations907 -* Modified: CSS for menu items when active (no hover). -* Added: Visual feedback to left menu if active. - -## 3.3.6.9 -* Fixed: #1623 - Registered older noUISlider JS under a new name to avoid conflicts. -* Modified: #1622 - Removed googlefonts.js dependency. - -## 3.3.6.8 -* Fixed: #1600 - ACE Editor bombing in PHP 5.2 environments. - -## 3.3.6.7 -* Fixed: #1591 - Erroneous outputting of font-weight and font-style when no font-family selected. -* Updated: #1569 - Improved submenu highlighting. -* Added: #1487 - Added `get_default_value` function into the framework.php - -## 3.3.6.6 -* Fixed: Framework URI errors when using child themes. Some restructuring. - -## 3.3.6.5 -* Fixed: Framework URI errors when embedded in theme with Windows. - -## 3.3.6.4 -* Added: image_size as an option for the data argument. Thanks @Gyroscopic! - -## 3.3.6.3 -* Modified: How Redux paths are run. Should cover all use cases now. Child themes can also embed - Redux properly now. Thanks @cfoellmann for the suggestions. Fix for issue #1566. - -## 3.3.6.2 -* Modified: How we declare the uploads directory and URL. Using core WP functions now. - -## 3.3.6.1 -* Modified: Now if a section is empty, but has subsections, that section will be "skipped" when - clicked and the first subsection will then be shown. - -## 3.3.6 -* Modified: Language files. -* Fixed: #1560 - IE8 RGBA fallack - -## 3.3.5.12 -* Fixed: #1543 - Hint icon not changing when set in args. - -## 3.3.5.11 -* Fixed: #1537 - Media field not accepting images with mode set to false. - -## 3.3.5.10 -* Fixed: #1529 - ACE Editor conflict with Visual Composer. -* Added: #1530 - Added argument to specify admin bar icon, `admin_bar_icon`. Thanks Ninos! -* Fixed: #1532 - Media field not accepting any mime type when `'mode' => false`. - -## 3.3.5.9 -* Fixed: #1520 - Checkbox field not displaying Wordpress data when using data argument. - -## 3.3.5.8 -* Fixed: #1516 - Invalid index and foreach when using compiler and async_typography. - -## 3.3.5.7 -* Fixed: #1509 - Sorter adding unnecessary bits on some items. -* Fixed: #1514 - Customizer and multisite not getting on properly. -* Fixed: #1512 - Slides 'Upload' button not showing or saving selected image. - -## 3.3.5.6 -* Fixed: Checkboxes with required were working in reverse. - -## 3.3.5.5 -* Fixed: ASync Typography now works! No more flashing fonts. - -## 3.3.5.4 -* Fixed: #1489 - Color picker UI lining up improperly. -* Fixed: #1497 - dev_mode spinner issue. - -## 3.3.5.3 -* Fixed: Spelling error in tracking dialog. -* Modified: Updated ace_editor. -* Modified: Many MANY fields for the group field. -* Fixed: Some CSS bugs. - -## 3.3.5.2 -* Fixed: #1481 - Custom fonts loading in google font CSS. -* Fixed: #1485 - Customizer 'invalid argument' error. Thanks @rnlmedia. - -## 3.3.5.1 -* Fixed: #1472 - font style not displaying saved valie with no font-family argument set. -* Fixed: #1471 - raw field and required not playing nice together. - -## 3.3.5 -* Added: An annoying notice at the top so our devs don't ship with dev_mode on. ;) - -## 3.3.4.9 -* Fixed: #1462 - Google fonts not loading in font drop down. - -## 3.3.4.8 -* Fixed: More WP FileSystem tanking. Did PHP fallback before FTP. Works 99.9% of the time without credentials. - -## 3.3.4.7 -* Fixed: Incorrect folder CHMOD in filesystem class. - -## 3.3.4.6 -* Fixed: #1454 - Chmod permissions for redux folder. - -## 3.3.4.5 -* Fixed: #1451 - Googlefonts not loading due to failing copy function. - -## 3.3.4.4 -* Fixed: #1450 - Saves witch values with no `on` or `off` args make the core unhappy. - -## 3.3.4.3 -* Fixed: #1444, again, due to filesystem growing pains. -* Fixed: #1449 - Restoring `options` argument over a lousy attempt to fix placeholder. - -## 3.3.4.2 -* Fixed: More file permission issues. - -## 3.3.4.1 -* Fixed: Font debug was left from last commit. Sorry all. - -## 3.3.3.8 -* Fixed: Issues with file writing. Basically many users don't install WordPress with all the permissions correct. - So... Had to move it back to /uploads/. Sorry Otto, that's just how it is. -* Fixed: #1444 - output of typography all_styles when font_style UI was hidden. - -## 3.3.3.7 -* Fixed: #1440 - flaw in new cleanFilePath logic. - -## 3.3.3.6 -* Fixed: #1432 - Theme check failing when double-slashes existed in get_template_directory() return. -* Removed: curlRead from helper class. - -## 3.3.3.5 -* Fixed: #1426 - menu_name not appearing on front end admin bar. -* Added: #1427 - button_set added to customizer UI. Thanks @wpexplorer. - -## 3.3.3.4 -* Fixed: #1429 - ACE Editor erroring with no default value set. -* Fixed: wp_filesystem now initialized with credentials in an effort to combat the tmp file issue. - -## 3.3.3.3 -* Modified: Code purification. - -## 3.3.3.2 -* Modified: How section tabs work. Isolated within the redux-container class. - -## 3.3.3 -* Modified: #1412 - Redesigned text label, placeholder fix. - -## 3.3.2.10 -* Fixed: #1408 & #1357 - Typography subsets losing value after multiple saves - on other panels. - -## 3.3.2.9 -* Fixed: #1403 - unit value no longer prints after empty typography values -* Modified: Typography: Backup font no longer appends to `font-family` variable. - Please use the `backup-font` variable to specify backup fonts. This - does not apply to output/compiler strings. - -## 3.3.2.8 -* Fixed: #1403 - Backup font not appearing in font-family variable. - -## 3.3.2.7 -* Modified: Customizer now supports section and field `permissions` argument. -* Fixed: #1399 - Customizer respects `page_permissions` argument. - -## 3.3.2.6 -* Fixed: #1400 - output/compiler string incomplete using multiple selectors. - -## 3.3.2.5 -* Fixed: #1396 - Custom fonts cutting off multiple families in selector, after save. -* Fixed: Typography attempting to queue up non google fonts on backend. -* Added: #1395 - Display of child theme status in sysinfo, thanks @SiR-DanieL. - -## 3.3.2.4 -* Fixed: #1387 - Page jump when clicking "Options Object". Thanks @rrikesh. -* Added: #1392 - Filters to change the following localized strings: - redux/{opt_name}/localize/reset - redux/{opt_name}/localize/reset_all - redux/{opt_name}/localize/save_pending - redux/{opt_name}/localize/preset - -## 3.3.2.3 -* Fixed: #1376 - checkbox.min.js missing. - -## 3.3.2.2 -* Fixed: Static variable changes for instances and basic comment cleanup - -## 3.3.2.1 -* Fixed: #1361 - Raw field not hiding with required. -* Fixed: Datepicker not formatting properly. Still needs some work. - -## 3.3.1.9 -* Fixed: #1357 - Preview not rendering font on page load. - -## 3.3.1.8 -* Fixed: #1356 - Color fields and transparency not syncing due to new JS. - -## 3.3.1.7 -* Fixed: #1354 - Add class check for W3_ObjectCache. - -## 3.3.1.6 -* Fixed: #1341 - JS not initializing properly in import_export. - -## 3.3.1.5 -* Fixed: #1339 - Typography would lose Font Weight and Style. value was - named val in the HTML, so it would be destroyed on the next save - if not initialized. - -## 3.3.1.4 -* Fixed: #1226 - W3 Total Cache was affecting validation and compiler hooks. -* Fixed: Menu errors weren't showing properly for non-subsectioned items. - -## 3.3.1.3 -* Fixed: #1341 - Import/Export buttons not functioning. Also fixed sortable somehow. - -## 3.3.1.2 -* Fixed: Slides not initializing with the last fix. - -## 3.3.1.1 -* Fixed: Slides field was not properly initialized for the media elements. Fixed. - -## 3.3.0.6 -* Fixed: #1337 - `redux` JS dependency loading issue. Many thanks @tpaksu - -## 3.3.0.5 -* Modified: Drastically changed the way JavaScript is used in the panel. Forced as-needed - initialization of fields. Thus reducing dramatically the overall load time of - the panel. The effects have been seen up to 300% speed improvement. The only - time a field will be initialized is if it's visible, thus reducing the processing - needed in DOM overall. - -## 3.3.0.4 -* Fixed: #1336 - fixed default font in preview. - -## 3.3.0.3 -* Fixed: #1334 - Typography not un-saving italics. - -## 3.3.0.2 -* Added: #1332 - New validation: numeric_not_empty. - -## 3.3.0.1 -* Fixed: #1330 - Required not working on all fields. - -## 3.3.0 -* Added: #1329 - `'preview' = array('always_display' => true)` argument to typography, to determine if preview field show always be shown. - -## 3.2.9.38 -* Fixed: #1322 - Sections not folding with required argument. -* Modified: Portions of core javascript rewritten into object code. - -## 3.2.9.37 -* Fixed: #1270 - Editor field compiler hook not firing in visual mode. - -## 3.2.9.36 -* Added: `hide_reset` argument, to hide the Reset All and Reset Section buttons. - -## 3.2.9.35 -* Fixed: select2 dependency in select_image, and other fields. - -## 3.2.9.34 -* Fixed: Filter out `@eaDir` directories in extensions folder. -* Added: `content_title` argument to slides field. Thanks @psaikali! - -## 3.2.9.33 -* Fixed: Fixed the image_select presets to work again. Also now will function even if import/export is disabled. - -## 3.2.9.32 -* Fixed: Minor tweaks for metabox update. - -## 3.2.9.31 -* Fixed: #1297 - Missing space in image_select class. -* Fixed: Slider field tweaked for metaboxes. - -## 3.2.9.30 -* Fixed: #1291 - Change of font-family would not trigger preview, or show in open preview. - -## 3.2.9.29 -* Fixed: #1289 - Typography not retaining size/height/spacing/word/letter spacing settings. - -## 3.2.9.28 -* Fixed: #1288 - Background color-picker dependency missing. Thanks @farhanwazir. - -## 3.2.9.27 -* Fixed: Search extension failed do to dependency issue from the core. - -## 3.2.9.26 -* Fixed: #1281 - color field output/compiler outputting incorrect selector when only one array present. - -## 3.2.9.25 -* Fixed: Update check only appears once if multiple instances of Redux are loaded in the same wordpress instance. - -## 3.2.9.24 -* Fixed: Changing font-family in typography didn't trigger 'save changes' notification. -* Fixed: More typography: Back up font appearing in font-family when opening selector. -* Fixed: Typography: undefined message when NOT using google fonts. Thanks @farhanwazir - -## 3.2.9.23 -* Added: `customizer_only` argument for fields & sections, contributed by @andreilupu. - -## 3.2.9.22 -* Fixed: Typography font backup not in sync with font-family. -* Fixed: Typography not saving font-family after switching back and forth between standard - and google fonts. -* Fixed: Background field selects not properly aligned. - -## 3.2.9.21 -* Added: select2 args for spacing field. -* Modified: All field javascript rewritten using jQuery objects (versus standard function). - Prepping for another crack at group field. - -## 3.2.9.20 -* Added: select2 args for the following fields: typography, background, border, dimensions and slider. -* Fixed: Removed select field dependency from background field. - -## 3.2.9.19 -* Fixed: #1264 - Color-picker/transparent checkbox functionality. -* Fixed: Typography fine-tuning. - -## 3.2.9.18 -* Modified: Typography field rewritten to fill out font-family field dynamically, versus on page load. -* Fixed: All typography select fields render as select2. - -## 3.2.9.17 -* Fixed: Switching between transparency on and off now restores the last chosen color in - all color fields. - -## 3.2.9.16 -* Fixed: Redux uploads dir should NOT be ~/wp-content/uploads, but just wp-content. - As per Otto. -* Fixed: Navigation no longer has that annoying outline around the links. Yuk. - -## 3.2.9.15 -* Fixed: #1218 - Select2 multi select not accepting any keyboard input. - -## 3.2.9.14 -* Fixed: #1228 - CSS fixes - -## 3.2.9.13 -* Fixed: #1255 - button_set multi field not saving when all buttons not selected. - -## 3.2.9.12 -* Fixed: #1254 - Border field with 0px not outputting properly. -* Fixed: #1250 - Typography preview font-size not set in preview. -* Fixed: #1247 - Spacing field not outputting properly in `absolute` mode. -* Modified: Typography previewing hidden until font inputs are changed. - -## 3.2.9.11 -* Fixed: Vendor js not loading properly when dev_mode = true -* Fixed: Border field not outputting properly. - -## 3.2.9.10 -* Modified: Centralized import/export code in anticipation of new builder features. -* Fixed: Removed rogue echo statement. - -## 3.2.9.9 -* Modified: select2 loads only when a field requires it. - -## 3.2.9.8 -* Modified: More code to load JS on demand for fields require it. - -## 3.2.9.7 -* Modified: Field specific JS only loads with active field. -* Fixed: Hints stopped working due to classname change. - -## 3.2.9.6 -* Fixed: Permissions argument on section array not filtering out raw field. - -## 3.2.9.5 -* Fixed: Too many CSS tweaks to list, due to last build. -* Fixed: Sortable and Sorter fields now sort without page scroll when page size is - under 782px. -* Fixed: Hint icon defaults to left position when screen size is under 782px. -* Fixed: `permissions` argument for fields and sections erasing saved field data. See #1231 - -## 3.2.9.4 -* Modified: Woohoo! Nearly fully responsive. Yanked out all SMOF and NHP field customizations. - Lots of little fixes on all browser screens. This will also greatly benefit Metaboxes - and other areas of Redux. -* Fixed: In dev_mode panel CSS was being loaded 2x. - -## 3.2.9.3 -* Fixed: Typography color picker bleeding under other elements. #1225 -* Fixed: Hint icon_color index error from builder. #1222 - -## 3.2.9.2 -* Fixed: Tracking. It was... odd. Also started our support hooks, UI to come. -* Fixed: Now import/export supports multiple instances. I can't believe this has been this way for so long. - -## 3.2.9.1 -* Fixed: Spacing field not outputting proper CSS when `mode` was set to absolute, and `all` was set to true. -* Fixed: CSS fix for typography. Color picker would interfere with save/reset bar. - -## 3.2.8.21 -* Added: Network admin support! Set argument 'database' to network and data will be saved site-wide. - Also two new arguments: network_admin & network_sites for where to show the panel. - -## 3.2.8.20 -* Fixed: Redux now ignores any directories that begin with `.` in the extension folder. See #1213. - -## 3.2.8.19 -* Fixed: Redux not saving when validating uploads. -* Modified: Dimension field default now accepts either `units` or `unit`. - -## 3.2.8.18 -* Fixed: Border field output/compiler formatting. Removed 'inherit' in place of default values. See #1208. -* Fixed: Trim() warning in framework.php when saving. See #1209, #1201. - -## 3.2.8.17 -* Fixed: Typography not outputting all styles when `all_styles` set to true. - -## 3.2.8.16 -* Added: `output` argument for `color` and `color_rgba` fields accepts key/pairs for different modes. Example: -``` - 'output' => array('color' => '.site-title, .site-header', 'background-color' => '.site-background') -``` - -## 3.2.8.15 -* Added: Customizer hook that can be used to simulate the customizer for live preview in the customizer. - `redux/customizer/live_preview` - -## 3.2.8.14 -* Fixed: 'Cannot send header' issues with typography. -* Modified: Google CSS moved into HEAD via WP enqueue. - -## 3.2.8.13 -* Added: `class` argument to the Redux Arguments, section array, and metabox array. If set, a class will be - appended to whichever level is used. This allows further customization for our users. - -## 3.2.8.12 -* Fixed: Small fix for validation if subsection parent is free of errors, remove the red highlight when - not expanded. -* Fixed: Small CSS classes for flashing fonts where web-font-loader. -* Fixed: ASync Flash on fonts. FINALLY. What a pain. -* Modified: Now do a trim on all fields before validating. No need to alert because of a space... - -## 3.2.8.11 -* Modified: Typography field CSS completely rewritten. All thanks to @eplanetdesign! -* Modified: Validation now works in metaboxes as well as updates numbers as changes occur. Validation for - subsections is SO hot now. -* Modified: Various CSS fixes and improvements. -* Fixed: 3+ JavaScript errors found in the background field. Now works flawlessly. -* Added: disable_save_warn flags to the arguments to disable the "you should save" slidedown. - -## 3.2.8.10 -* Fixed: PHP warnings in background field. #1173. Thanks, @abossola. -* Fixed: CSS validation not respecting child selector symbol. #1162 - -## 3.2.8.9 -* Modified: Turned of mod_rewrite check. - -## 3.2.8.8 -* Modified: How errors are displayed, no longer dependent on the ID, now proper classes. -* Fixed: Extra check for typography bug. -* Fixed: Error css alignment issue with subsections. -* Modified: Error notice stays until all errors are gone. Also updates it's number as errors fixed! - -## 3.2.8.7 -* Modified: Moved google font files to proprietary folder in upload to help with permission issues. - -## 3.2.8.6 -* Fixed: javascript error in typography field. - -## 3.2.8.5 -* Fixed: Added a title to the google fonts stylesheet to fix validation errors. - -## 3.2.8.4 -* Fixed: One more slides field error check, and an extra JS goodie for an extension. - -## 3.2.8.3 -* Fixed: Leftover debug code messing up slides field. - -## 3.2.8.2 -* Fixed: More reliable saved action hook. -* Added: Actions hooks for errors and warnings. - -## 3.2.8.1 -* Fixed: Removed erroneous debug output in link_color field. - -## 3.2.7.3 -* Added: is_empty / empty / !isset AND not_empty / !empty / isset as required operations - -## 3.2.7.2 -* Fixed: Reset defaults error. -* Added: `show` argument to turn on and off input boxes in slider. - -## 3.2.7.1 -* Fixed: Required now works with muti-check fields and button set when set to multi. - -## 3.2.7 -* Fixed: Import works again. A single line was missed... - -## 3.2.6.2 -* Fixed: link_color field not outputting CSS properly via compiler or output. Thanks @vertigo7x -* Fixed: Sorter field CSS. Buttons were all smushed together. - -## 3.2.6.1 -* Fixed: 'undefined' error in typography.js. Thanks @ksere. - -## 3.2.6 -* Fixed: Another stray undefined index. Oy. - -## 3.2.5.1 -* Added: `open_expanded` argument to start the panel completely expanded initially. - -## 3.2.5 -* Fixed: Various bad mistakes. Oy. - -## 3.2.4 -* Fixed: Slight typography speed improvement. Less HTML hopefully faster page loads. -* Fixed: Unload error on first load if the typography defaults are not set. - -## 3.2.3.5 -* Modified: Moved update check functions to class file and out of the core. -* Fixed: Errors pertaining to mod_rewrite check. - -## 3.2.3.4 -* Fixed: All those headers already set errors. - -## 3.2.3.3 -* Added: $changed_values variable to save hooks denoting the old values on a save. -* Added: Pointers to Extensions on load. -* Modified: CSS Output for the background field. - -## 3.2.3.2 -* Fixed: Validation error messages not appearing on save. -* Modified: Speed boost on validation types. -* Added: Apache mod_rewrite check. This should solve many issues we've been seeing regarding mod_rewrite noe being enabled. - -## 3.2.3.1 -* Fixed: Sortable field not saving properly. -* Fixed: Erroneous data in admin.less -* Updated: sample-config.php. Sortable checkbox field example now uses true/false instead of text - meant for textbox example. - -## 3.2.3 -* Fixed: Responsive issues with spacing and dimension fields. - -## 3.2.2.16 -* Fixed: Style conflicts with WP 3.9. Added register filter to fields via id. - -## 3.2.2.15 -* Fixed: Metaboxes issues. - -## 3.2.2.14 -* Modified: Some admin panel stylings. Now perfect with mobile hover. Also fixed an issue - with the slidedown width for sections. No more 2 empty pixels. - -## 3.2.2.13 -* Added: Tick mark if section has sub sections. Hidden when subsections expanded. - -## 3.2.2.12 -* Fixed: Compiler hook in the customizer now passes the CSS. - -## 3.2.2.11 -* Fixed: Compiler hook now properly fires in the customizer. - -## 3.2.2.10 -* Fixed: Validation error with headers already being set. - -## 3.2.2.9 -* Fixed: Added mode for width/height to override dimensions css output. - -## 3.2.2.8 -* Fixed: Restoring lost formatting from multiple merges. - -## 3.2.2.7 -* Fixed: New sorter default values get set properly now. ;) - -## 3.2.2.6 -* Added: `data` and `args` can now be set to sorter! Just make sure to have it be a key based on what - you want it to display as. IE: `array('Main'=>'sidebars')` - -## 3.2.2.5 -* Added: Prevent Redux from firing on AJAX heartbeat, but added hook for it 'redux/ajax/heartbeat'. -* Fixed: Removed erroneous 's' character from HTML. - -## 3.2.2.4 -* Added: Check to make sure a field isn't empty after the filter. If it is empty, skip over it. - -## 3.2.2.3 -* Added: Subsections now show icon if they have it. Show text only (without indent) if they do not. - -## 3.2.2.2 -* Added: Set a section or field argument of `'panel' => false` to skip over that field or panel and - hide it. It will still be registered with defaults saved, but not display. This can be useful - for things like the customizer. - -## 3.2.2.1 -* Added: SUBSECTIONS! Just add `'subsection' => true` to any section that isn't a divide/callback and - isn't the first section in your panel. ;) - -## 3.2.1.2 -* Fixed: Info field didn't intend within section. - -## 3.2.1.1 -* Fixed: Compiler hook wasn't running. - - -## 3.1.9.44 -* Fixed: Small bug in image_select javascript. - -## 3.1.9.43 -* Added: Import hook, just because we can. :) - -## 3.1.9.42 -* Fixed: Customizer now TRULY outputting CSS if output_tag is set to false. - -## 3.1.9.41 -* Fixed: Reset section, etc. Discovered an odd WordPress thing. - -## 3.1.9.40 -* Fixed: Image_select size override. -* Fixed: Customizer save not firing the compiler hook. -* Fixed: Customizer not outputting CSS if output_tag is set to false. -* Fixed: Small empty variable check. Undefined index in the defaults generating function. - -## 3.1.9.39 -* Fixed: WP 3.9 update made editor field button look ugly. -* Fixed: Save hook not firing when save_default set to false. - -## 3.1.9.38 -* Fixed: Reset section anomalies. Maybe. - -## 3.1.9.37 -* Fixed: Array of values in required not recognized. - -## 3.1.9.36 -* Fixed: Updated hint defaults to prevent index warning. - -## 3.1.9.35 -* Fixed: Removed leftover debug code. - -## 3.1.9.34 -* Added: New readonly argument for text field. - -## 3.1.9.33 -* Fixed: Reset/Reset section actions hooks now fire properly. - -## 3.1.9.32 -* Fixed: When developer uses section field but does not specify an indent argument. - -## 3.1.9.31 -* Fixed: Dynamic URL for slides -* Fixed: Accidently removed reset action on section reset. Restored. - -## 3.1.9.30 -* Fixed: Section defaults bug for certain field types. - -## 3.1.9.29 -* Fixed: Dynamic URL if site URL changed now updates media properly if attachement exists. - -## 3.1.9.28 -* Fixed: Customizer now correctly does live preview. - -## 3.1.9.27 -* Fixed: Special enqueue case fix. - -## 3.1.9.26 -* Added: A few more hooks for defaults and options. -* Fixed: Small undefined index error. -* Added: Section key generation via title. -* Modified: File intending. - -## 3.1.9.25 -* Fixed: Custom menus not displaying options panel. - -## 3.1.9.24 -* Fixed: Single checkbox option not retaining checked value. -* Fixed: Border field returning bad CSS in CSS compiler. - -## 3.1.9.23 -* Fixed: Import/Export fix. Thanks, CGlingener! - -## 3.1.9.22 -* Added: Save warning now is sticky to the top and responsive. -* Fixed: Mobile fixes for Redux. Looks great on small screens how. -* Fixed: Slight CSS fixes. -* Fixed: Compiler fixes and added notices. -* Added: Import/Export more reasonable text. - -## 3.1.9.21 -* Added: `force_output` are on the field level to bypass the required check that removes the output - if the field is hidden. Thanks @rffaguiar. - -## 3.1.9.20 -* Fixed: Rare case (mediatemple grid server) when file_get_contents won't work outside of the - uploads dir. Used curl to grab the font HTML. ;) - -## 3.1.9.19 -* Fixed: Undefined index for admin bar. - -## 3.1.9.18 -* Fixed: SMALL issue with WordPress 3.9. Now it works. ;) - -## 3.1.9.17 -* Fixed: Info and divide field now work with required. - -## 3.1.9.16 -* Added: Fallback. Now if the media, slides, or background URL doesn't match the site URL, but the - attachment ID is present, the data is updated. - -## 3.1.9.15 -* Fixed: Last tab not properly set. Slow rendering. - -## 3.1.9.14 -* Modified: Replaced transients with cookies. - -## 3.1.9.13 -* Fixed: Undefined variable issues for new required methods. - -## 3.1.9.12 -* Fixed: Default_show display error with a non-array being steralized. -* Added: Multiple required parent value checking! Booya! -* Fixed: Sections now fold with required. - -## 3.1.9.11 -* Fixed: select2 not rendering properly when dev_mode = false, because of ace_editor fix. -* Fixed: Removed mistakenly compiled test code from redux.js. - -## 3.1.9.10 -* Fixed: ace_editor not rendering properly in certain instances. -* Modified: Small change to import_export field in checking for existing instance of itself. - -## 3.1.9.9 -* Fixed: import_export not rendering when the menutype argument was set to menu - -## 3.1.9.8 -* Fixed: Ace_editor not enqueued unless used. MEMORY HOG. - -## 3.1.9.7 -* Fixed: Color_Gradient transparency to was being auto-selected if from way transparent. -* Fixed: Enqueue select with slider for local dev. - -## 3.1.9.6 -* Modified: removed add_submenu_page when creating a submenu for us in the WP admin area. WP - approved API is used in it's place to being Redux up to wp.org theme check standards. - -## 3.1.9.5 -* Fixed: Massive speed issue with button_set. Resolved. -* Fixed: Issue where default values throws an error if ID is not set. - -## 3.1.9.4 -* Fixed: Continuing effort to ensure proper loading of config from child themes. - -## 3.1.9.3 -* Fixed: Import/Export array search bug if section['fields'] is not defined. - -## 3.1.9.2 -* Fixed: Inconsistencies in import/export across different versions of PHP. - -## 3.1.9.1 -* Fixed: Redux checks for child or parent theme exclusively before loading. - -## 3.1.9 -* Updated: RGBA Field stability. Thank you, SilverKenn. - -## 3.1.8.23 -* Modified: Separated Import/Export from the core. It can now be used as a field. - -## 3.1.8.22 -* Fixed: Typography custom preview text/size not outputting. -* Fixed: No font selected in typography would default to 'inherit'. -* Fixed: Hint feature kicking back a notice if no title was specified. - -## 3.1.8.21 -* Fixed: Sortable field, when used a checkboxes, were all checked by default, even when set not to be. -* Fixed: button_set field not setting properly in multi mode. - -## 3.1.8.20 -* Fixed: Javascript console object not printing options object. -* Fixed: Load errors from child themes no longer occur. - -## 3.1.8.19 -* Modified: Typography word and letter spacing now accept negative values. -* Modified: Typography preview shows spaces between upper and lower case groupings. -* Fixed: Compiler output for slider field. - -## 3.1.8.18 -* Fixed: update_check produced a fatal error on a local install with no internet connection. -* Modified: Google font CSS moved to header so pages will pass HTML5 validation. - -## 3.1.8.17 -* Fixed: Compiler hook failing on slider. - -## 3.1.8.16 -* Fixed: Error on update_check when the response code was something other than 200. -* Modified: Removed Google font CSS line from header (because it's in the footer via wp_enqueue_style. - -## 3.1.8.15 -* Added: Admin notice for new builds of Redux on Github as they become available. This feature is - available on in dev_mode, and may be turned off by setting the `update_notice` argument to - false. See the Arguments page of the wiki for more details. -* Added: text-transform option for the typography field. -* Fixed: image_select images not resizing properly in FF and IE. -* Fixed: Layout for the typography field, so everything isn't smushed together. The new layout is - as follows: - [family-font] [backup-font] - [style] [script] [align] [transform] - [size] [height] [word space] [letter space] - [color] - -## 3.1.8.14 -* Added: Newsletter sign-up popup at first load of the Redux options panel. - -## 3.1.8.12 -* Added: Added PHP 5.2 support for import/export. - -## 3.1.8.11 -* Added: Action hooks for options reset and options reset section. -* Added: Theme responsive for date picker. - -## 3.1.8.10 -* Added: New slider. Better looking UI, double handles and support for floating - point values. See the wiki for more info. - -## 3.1.8.9 -* Fixed: link_color field showing notice on default, if user enters no defaults. -* Fixed: Fixed tab notice in framework.php if no tab parameter is set in URL. - -## 3.1.8.8 -* Added: Typography improvements. - -## 3.1.8.7 -* Added: Hints! More info: https://github.com/ReduxFramework/ReduxFramework/wiki/Using-Hints-in-Fields - -## 3.1.8.6 -* Added: Complete Wordpress admin color styles. Blessed LESS/SCSS mixins. ;) - -## 3.1.8.5 -* Added: Font family not required for the typography module any longer. - -## 3.1.8.4 -* Added: Support for using the divide field in folding. -* Added: Error trapping in typography.js for those still attempting to use - typography with no font-family. - -## 3.1.8.3 -* Added: Full asynchronous font loading. -* -## 3.1.8.2 -* Added: email_not_empty validation field. -* Reverted: email validation field only checks for valid email. not_empty check moved - to new validation field. - -## 3.1.8.1 -* Fixed: Hide demo hook wasn't hiding demo links. - -## 3.1.8 -* Fixed: Improper enqueue in tracking class. -* Fixed: Few classes missed for various fields. -* Fixed: Spacing field kicking back notices and warnings when 'output' wasn't set. -* Modified: Added file_exists check to all include lines in framework.php -* Fixed: Background field now works with dynamic preview as it should. -* Fixed: Extension fields now enqueueing properly. -* Added: Text-align to typography field. -* Fixed: Servers returning forwards slashes in TEMPLATEPATH, while Redux is installed - embedded would not show options menu. -* Fixed: On and Off for switch field not displaying language translation. -* Fixed: email validation allowing a blank field. -* Fixed: Now allow for empty values as valid keys. -* Added: Dismiss option to admin notices (internal function) - -## 3.1.6 -* Fixed: CSS spacing issue -* Fixed: Customizer now works and doesn't break other customizer fields outside of Redux. -* Fixed: Several minor bug fixes -* Added: Metabox support via extension http://reduxframework.com/extensions/ -* Added: Admin-bar menu -* Fixed: Section field now folds. -* Fixed: wp_content_dir path now handles double forward slashes. -* Fixed: Typography field missing italics in Google fonts. -* Fixed: Default color in border field not saving properly. -* Fixed: hex2rgba in class.redux_helpers.php changed to static. -* Fixed: 'sortable' field type not saving options as default. -* Fixed: Specified default color not set when clicking the color box default button. -* Fixed: Sorter field options are now saved as default in database. -* Fixed: Issues with checkboxes displaying default values instead of labels. -* Fixed: Outstanding render issues with spacing field. -* Fixed: Plugins using Redux from load failure. -* Fixed: 'not_empty' field validation. -* Fixed: Media field. -* Added: 'read-only' option for media text field. -* Added: 'mode' option to image_select, so CSS output element may be specified. -* Added: Admin Bar menu for option panel. -* Modified: Removed raw_align field and added align option to raw field. - See wiki for more info. -* Modified: media field 'read-only' to 'readonly' to vonform to HTML standards. -* Removed: EDD extension. It never belonged in Core and will be re-released as a - downloadable extension shortly -* Removed: Group field, temporarily. -* Removed: wp_get_current_user check. - -## 3.1.5 -* Typography font arrays may not contain comma spaces. -* Merge in pull request - 542, code cleanup and better readability -* Change how HTML is output to support metaboxes -* CSS only on pages that matter, better checks. -* font-backup in typography now appends to font-family in output and compiler. -* More fixes for Google font css outputting. -* Addded output and compiler to field_image_select. Images will be output as 'background-image'. -* Fixed output in field_background. -* Prevent standard fonts from outputting to Google fonts CSS call. -* class_exists in field_section checking for incorrect classname. -* sample_config fix. -* Compiler not outputting CSS without output set to comthing other than false. -* Google fonts not rendering on frontend. -* Rewrote sample_config as a class - -## 3.1.4 -* Fixed error in redux-framework.php. -* Added select_image field. - -## 3.1.3 -* Fixed a few undefined variables -* Removed old code from the repo. -* Fix for validation. -* Remove the compiler hook by default. -* Fix to sortable field. -* Added an extra check for link color. Removes user error. -* Localization updates. -* Error in slides. -* Fixed the info box bug with spacing and padding. -* Fixed the first item in each section having WAY too much padding. ;) -* Fixed section reset issue where values weren't being saved to the db properly. - -## 3.1.2 -* Feature - Sortable select boxes! -* Feature - Reset a section only or the whole panel! -* New Field - RGBA Color Field! -* Improvement - Use of REM throughout. -* Fixed Typography - Fix output option and various small bugs. -* Fixed Border - Fix output option and various small bugs. -* Fixed Dimensions - Fix output option and various small bugs. -* Fixed Image_select - Various small bugs. -* Fixed Slides - Various small bugs. -* Fixed Sortable - Using native jQuery UI library same as within WordPress. -* Fixed Slider and Spinner Input Field - Values now move to the closest valid - value in regards to the step, automatically. -* Fixed Ace Editor -* FEATURE - All CSS/JS files are compiled into a single file now! Speed - improvements for the backend. -* Fix in how WordPress data is received, improved some output. -* Fix for various fields not triggering fold/compiler/save. -* Fixed elusive icons to use the new version and classes. -* Fixed media thumb to only be the thumbnail version. -* Fixed admin https error with WordPress core not renaming URL. -* Placeholders throughout the framework are now properly there. -* Feature - Setting to not save defaults to database on load. -* Fixed - Computability issue with GT3 builder. -* Fixed localization issue with default values. -* Language - Added Russian -* Feature - Media now can have any content type passed in to limit content types. -* Allow negative values in typography and other fields. -* WordPress 3.8 computability. -* CSS validation issue. -* Feature - User contributed text direction feature. -* EDD Extension now fully function for plugins or themes. -* Removed get_theme_data() fallbacks, we're well pass WordPress 3.4 now. ;) -* A ton of other small updates and improvements. - -## 3.1.0 -* Fix Issue 224 - Image Select width was breaking the panel. -* Fix Issue 181 - Broken panel in firefox -* Fix Issue 225 - 0px typography bug. Thanks @partnuz. -* Fix Issue 228 - Resolved a duplicated enqueue on color_link field. Thanks @vertigo7x. -* Fix Issue 231 - Field spacing bug fixes. -* Fix Issue 232 & 233 - Dimensions: bug fix with units and multiple units. Thanks @kpodemski -* Fix Issue 234 - Pass options as a ref so validating actions can modify/sanitize them. Thanks @ZeroBeeOne -* Fix Issue 222 - Tab cookie function wasn't working. -* Feature - Pass params to Select2. Thanks @andreilupu -* Fix Issue 238 - Fix for conditional output. Thanks @partnuz. -* Fix Issue 211 - Google Web font wasn't loading at first init of theme. -* Fix Issue 210 - Elusive Icons update. Changed classes to force use of full elusive name. -* Fix Issue 247 - Media thumbnails were not showing. Also fixed media to keep the largest file, but display the small - version in the panel as a thumb. Thanks @kwayyinfotech. -* Fix Issue 144 - JS error when no item found in slider. -* Fix Issue 246 - Typography output errors. -* Feature & Issue 259 - Multi-Text now support validation! -* Fix Issue 248/261 - Links color issue. Also fixed color validation. -* Feature & Issue 262 - Now registered sidebars can be used as a data type. -* Fix Issue 194/276 - Custom taxonomy terms now passing properly. Thanks @kprovance. -* Feature & Issue 273 - Argument save_defaults: Disable the auto-save of the default options to the database if not set. -* Feature - Docs now being moved to the wiki for community participation. -* Issue 283 - Date placeholder. Thanks @kprovance. -* Issue 285 - HTTPS errors on admin. Known WordPress bug. Resolved. -* Fix Issue 288 - Float values now possible for border, dimensions, and spacing. -* Feature - Media field can now accept non-image files with a argument being set. -* Fix Issue 252 - Post Type data wasn't working properly. Thanks @Abu-Taymiyyah. -* Fix Issue 213 - Radio and Button Set wasn't folding. - -## 3.0.9 -* Feature - Added possibility to set default icon class for all sections and tabs. -* Feature - Make is to the WP dir can be moved elsewhere and Redux still function. -* Added Spanish Language. Thanks @vertigo7x. -* Fix Issue 5 - Small RGBA validation fix. -* Fix Issue 176 - Fold by Image Select. Thanks @andreilupu. -* Fix Issue 194 - Custom taxonomy terms in select field. -* Fix Issue 195 - Border defaults not working. -* Fix Issue 197 - Hidden elements were showing up on a small screen. Thanks @ThinkUpThemes. -* Fix issue 200 - Compiler not working with media field. -* Fix Issue 201 - Spacing field not using default values. -* Fix Issue 202 - Dimensions field not using units. -* Fix Issue 208 - Checkbox + Required issue. -* Fix Issue 211 - Google Font default not working on page load. -* Fix Issue 214 - Validation notice not working for fields. -* Fix Issue 181/224 - Firefox 24 image resize errors. -* Fix Issue 223 - Slides were losing the url input field for the image link. -* Fix - Various issues in the password field. -* Fixed various spelling issues and typos in sample-config file. -* Initialize vars before extract() - to shut down undefined vars wargnings. -* Various other fixes. - -## 3.0.8 -* Version push to ensure all bugs fixes were deployed to users. Various. - -## 3.0.7 -* Feature - Completely redone spacing field. Choose to apply to sides or all at once with CSS output! -* Feature - Completely redone border field. Choose to apply to sides or all at once with CSS output! -* Feature - Added opt-in anonymous tracking, allowing us to further analyze usage. -* Feature - Enable weekly updates of the Google Webfonts cache is desired. Also remove the Google Webfont files from - shipping with Redux. Will re-download at first panel run to ensure users always have the most recent copy. -* Language translation of german updated alone with ReduxFramework pot file. -* Fix Issue 146 - Spacing field not storing data. -* Fix - Firefox field description rendering bug. -* Fix - Small issue where themes without tags were getting errors from the sample data. - -## 3.0.6 -* Hide customizer fields by default while still under development. -* Fix Issue 123 - Language translations to actually function properly embedded as well as in the plugin. -* Fix Issue 151 - Media field uses thumbnail not full image for preview. Also now storing the thumbnail URL. Uses - the smallest available size as the thumb regardless of the name. -* Fix Issue 147 - Option to pass params to select2. Contributed by @andreilupu. Thanks! -* Added trim function to ace editor value to prevent whitespace before and after value keep being added -* htmlspecialchars() value in pre editor for ace. to prevent html tags being hidden in editor and rendered in dom -* Feature: Added optional 'add_text' argument for multi_text field so users can define button text. -* Added consistent remove button on multi text, and used sanitize function for section id -* Feature: Added roles as data for field data -* Feature: Adding data layout options for multi checkbox and radio, we now have quarter, third, half, and full - column layouts for these fields. -* Feature: Eliminate REDUX_DIR and REDUX_URL constants and instead created static ReduxFramework::$\_url and - ReduxFramework::$\_dir for cleaner code. -* Feature: Code at bottom of sample-config.php to hide plugin activation text about a demo plugin as well as - code to demo how to hide the plugin demo_mode link. -* Started work on class definitions of each field and class. Preparing for the panel builder we are planning to make. - -## 3.0.5 -* Fixed how Redux is initialised so it works in any and all files without hooking into the init function. -* Issue #151: Added thumbnails to media and displayed those instead of full image. -* Issue #144: Slides had error if last slide was deleted. -* Color field was outputting hex in the wrong location. -* Added ACE Editor field, allowing for better inline editing. - -## 3.0.4 -* Fixed an odd saving issue. -* Fixed link issues in the framework -* Issue #135: jQuery UI wasn't being properly queued -* Issue #140: Admin notice glitch. See http://reduxframework.com/2013/10/wordpress-notifications-custom-options-panels/ -* Use hooks instead of custom variable for custom admin CSS -* Added "raw" field that allows PHP or a hook to embed anything in the panel. -* Submenus in Admin now change the tabs without reloading the page. -* Small fix for multi-text. -* Added IT_it and RO_ro languages. -* Updated readme file for languages. - -## 3.0.3 -* Fixed Issue #129: Spacing field giving an undefined. -* Fixed Issue #131: Google Fonts stylesheet appending to body and also to the top of the header. Now properly placed - both at the end of the head tag as to overload any theme stylesheets. -* Fixed issue #132 (See #134, thanks @andreilupu): Could not have multiple WordPress Editors (wp_editor) as the - same ID was shared. Also fixed various styles to match WordPress for this field. -* Fixed Issue #133: Issue when custom admin stylesheet was used, a JS error resulted. - -## 3.0.2 -* Improvements to slides, various field fixes and improvements. Also fixed a few user submitted issues. - -## 3.0.1 -* Backing out a bit of submitted code that caused the input field to not properly break. - -## 3.0.0 -* Initial WordPress.org plugin release. - -## 3.0 -Redux is now hosted on WordPress.org! Update in order to get proper, stable updates. - -* Removed get() and show() -* Fixed huge performance bug -* More bugfixes -* Fixed spacing field -* Converted Redux to run as an auto-updating plugin. Getting ready to post to WordPress.org -* Fixed the auto updater to properly show changes since the last update -* Various fields including link_color, spacing, dimensions -* Compiler hooks to allow developers to generate CSS files only when needed -* Stability and standardizing in HTML output throughout -* PHP/CSS/JS fixes -* Compress JS and use LESS (and compressed CSS) throughout - -## Version 3.0.0 Beta (September 12, 2013) - -* Massive code overhaul -* Replaced redundant field types with data elements -* Migrated to company repo -* Added several new storage methods -* Numerous bugfixes -* Renamed std argument to default -* Added MP6 support -* Complete CSS rewrite -* Globals are now conditional -* Added nesting support -* Added repeatable field -* Restyled Dev Mode -* Added System Info tab -* Added compiler hooks -* Added style and icon support to info field -* Switched to Elusive Icons -* Huge performance updates - -## Version 2.0.1 Final (September 1, 2013) - -* Added option to override ```icon_type``` per icon -* Minor bug/versioning fixes -* Added Font Awesome intro -* Added ```raw_html``` option -* Added ```text_sortable``` option -* Switched from Aristo to Bootstrap jQuery UI theme - -## Version 2.0.0 (January 31, 2013) - -* Fixed SSL error which occurred occasionally with Google Webfonts -* Added optional flag for ```wpautop``` on editors -* Added password field type -* Added ```checkbox_hide_all``` option -* Added WP3.5 media chooser -* Added Google webfonts previews -* Updated to WP3.5 color picker -* Minor style tweaks -* Added graphical 'switch' option for checkboxes -* Removed dependency on class extension for fields -* Deprecated icons in favor of iconfonts - -## Version 1.0.0 (December 5, 2012) - -* Based on NHP Theme Options Framework v1.0.6 -* Cleaned up codebase -* Changed option group name to allow multiple instances -* Changed checkbox name attribute to id -* Added rows attribute to textareas -* Removed extra linebreak in upload field -* Set default menu position to null to avoid conflicts -* Added sample content for dashboard credit line -* Minor style changes -* Changed name of upload button -* Refactored Google Webfonts function -* Replaced ```stylesheet_override``` with ```admin_stylesheet``` -* Made text domain a constant -* Removed PHP closing tags to prevent issues with newlines -* Added option to define custom start tab diff --git a/library/admin/CONTRIBUTING.md b/library/admin/CONTRIBUTING.md deleted file mode 100644 index e54899de..00000000 --- a/library/admin/CONTRIBUTING.md +++ /dev/null @@ -1,27 +0,0 @@ -First and foremost, PLEASE check to see if you are using the latest version of Redux by checking the repository. If you plan on reporting an issue with any version BUT the latest version, we are going to ask you to upgrade to the latest code base anyway to see if your issue persists. Please save us and yourself some time by taking this simple step first. Thanks! - -When submitting a ticket, please make sure you include the following information, It is critical, and required. As Team Redux has not yet earned their certificates in mind reading, we need you to provide for us the following information. :) - -1. The version of Redux you are using. Please do not say 'the latest version' as what you perceive as the latest and what might be the latest could easily be two different things. At the bottom of the Redux options panel is a four digit version number. Please include it. - -2. The version of Wordpress you are running. - -3. Please indicate if you are using Redux in dev_mode. - -4. If you are having difficultly with a particular field, please include the config code for that entire field. If the field is dependent on other fields in the section (for example, required arguments are used), then please include the entire section. - -5. If you are having difficulty with configuration, please specify if you are using a standalone theme, a child theme, a plugin, etc. - -6. Please indicate if you are using Redux as a plugin or embedded in your project. - -7. Please check your browser's output console. If there are any javascript errors pertaining to redux, please list them, including the module/file they occurred in and the line number - -The follow only applies if Redux is not loading properly: - -8. If you are using Redux embedded, please specify the location in which Redux is installed, where you config is located, and the lines of code you are using to initialize Redux and your config. - -The way in which we diagnose bugs or config difficulties is to attempt to recreate them on our end. This is why we need the very specific information. Once we are able to confirm the issue, we will either push an update, or assist you in correcting any mistakes in your config. - -What we do NOT do is debug your code. We support the Redux code and the way in which the config is put together. Any other issue pertaining to your project is your own, or we might be able to assist with premium support. - -- Team Redux diff --git a/library/admin/Gruntfile.js b/library/admin/Gruntfile.js deleted file mode 100644 index af3c6cab..00000000 --- a/library/admin/Gruntfile.js +++ /dev/null @@ -1,439 +0,0 @@ -/* jshint node:true */ -var shell = require( 'shelljs' ); - -module.exports = function( grunt ) { - - // Project configuration. - grunt.initConfig( - { - pkg: grunt.file.readJSON( 'package.json' ), - - concat: { - options: { - separator: ';' - }, - core: { - src: [ - 'ReduxCore/assets/js/vendor/cookie.js', - 'ReduxCore/assets/js/vendor/jquery.typewatch.js', - 'ReduxCore/assets/js/vendor/jquery.serializeForm.js', - 'ReduxCore/assets/js/vendor/jquery.alphanum.js', - 'ReduxCore/assets/js/redux.js' - ], - dest: 'ReduxCore/assets/js/redux.min.js' - }, - vendor: { - src: [ - 'ReduxCore/assets/js/vendor/cookie.js', - 'ReduxCore/assets/js/vendor/jquery.serializeForm.js', - 'ReduxCore/assets/js/vendor/jquery.typewatch.js', - 'ReduxCore/assets/js/vendor/jquery.alphanum.js' - ], - dest: 'ReduxCore/assets/js/vendor.min.js' - } - }, - 'gh-pages': { - options: { - base: 'docs', - message: 'Update docs and files to distribute' - }, - dev: { - src: ['docs/**/*', 'bin/CNAME'] - }, - travis: { - options: { - repo: 'https://' + process.env.GH_TOKEN + '@github.com/ReduxFramework/docs.reduxframework.com.git', - user: { - name: 'Travis', - email: 'travis@travis-ci.org' - }, - silent: false - }, - src: ['**/*'] - } - }, - uglify: { - fields: { - files: [ - { - expand: true, - cwd: 'ReduxCore/inc/fields', - src: ['**/*.js', '!**/*.min.js', '!ace_editor/vendor/*.js', '!ace_editor/vendor/snippets/*.js', '!slider/vendor/nouislider/*.*', '!spinner/vendor/*.*'], - ext: '.min.js', - dest: 'ReduxCore/inc/fields' - } - ] - }, - extensions: { - files: [ - { - expand: true, - cwd: 'ReduxCore/inc/extensions', - src: ['**/*.js', '!**/*.min.js'], - ext: '.min.js', - dest: 'ReduxCore/inc/extensions' - } - ] - }, - core: { - files: { - 'ReduxCore/assets/js/redux.min.js': [ - 'ReduxCore/assets/js/redux.min.js' - ], - 'ReduxCore/assets/js/vendor/spectrum/redux-spectrum.min.js': [ - 'ReduxCore/assets/js/vendor/spectrum/redux-spectrum.js' - ], - 'ReduxCore/assets/js/vendor/redux.select2.sortable.min.js': [ - 'ReduxCore/assets/js/vendor/redux.select2.sortable.js' - ], - 'ReduxCore/assets/js/media/media.min.js': [ - 'ReduxCore/assets/js/media/media.js' - ] - } - - }, - vendor: { - files: { - 'ReduxCore/assets/js/vendor.min.js': [ - 'ReduxCore/assets/js/vendor.min.js' - ] - } - } - }, - qunit: { - files: ['test/qunit/**/*.html'] - }, - - // JavaScript linting with JSHint. - jshint: { - options: { - jshintrc: '.jshintrc' - }, - files: [ - //'Gruntfile.js', - //'ReduxCore/assets/js/import_export/import_export.js', - 'ReduxCore/assets/js/media/media.js', - 'ReduxCore/inc/fields/ace_editor/field_ace_editor.js', - 'ReduxCore/inc/fields/background/field_background.js', - 'ReduxCore/inc/fields/border/field_border.js', - 'ReduxCore/inc/fields/button_set/field_button_set.js', - 'ReduxCore/inc/fields/checkbox/field_checkbox.js', - 'ReduxCore/inc/fields/color/field_color.js', - 'ReduxCore/inc/fields/color_rgba/field_color_rgba.js', - 'ReduxCore/inc/fields/date/field_date.js', - 'ReduxCore/inc/fields/dimensions/field_dimensions.js', - 'ReduxCore/inc/fields/editor/field_editor.js', - 'ReduxCore/inc/fields/gallery/field_gallery.js', - 'ReduxCore/inc/fields/image_select/field_image_select.js', - 'ReduxCore/inc/fields/multi_text/field_multitext.js', - 'ReduxCore/inc/fields/palette/field_palette.js', - 'ReduxCore/inc/fields/select/field_select.js', - 'ReduxCore/inc/fields/select_image/field_select_image.js', - 'ReduxCore/inc/fields/slider/field_slider.js', - 'ReduxCore/inc/fields/slides/field_slides.js', - 'ReduxCore/inc/fields/sortable/field_sortable.js', - 'ReduxCore/inc/fields/sorter/field_sorter.js', - 'ReduxCore/inc/fields/spacing/field_spacing.js', - 'ReduxCore/inc/fields/spinner/field_spinner.js', - 'ReduxCore/inc/fields/switch/field_switch.js', - 'ReduxCore/inc/fields/typography/field_typography.js', - // 'ReduxCore/inc/fields/**/*.js', - 'ReduxCore/extensions/**/*.js', - 'ReduxCore/extensions/**/**/*.js', - 'ReduxCore/assets/js/redux.js' - ] - }, - - // Watch changes for files. - watch: { - ui: { - files: ['<%= jshint.files %>'], - tasks: ['jshint'] - }, - php: { - files: ['ReduxCore/**/*.php'], - tasks: ['phplint:core'] - }, - css: { - files: ['ReduxCore/**/*.less'], - tasks: ['less:development'] - } - }, - - // Add textdomain. - addtextdomain: { - options: { - textdomain: 'redux-framework', // Project text domain. - updateDomains: ['redux', 'redux-framework-demo', 'v'] // List of text domains to replace. - }, - target: { - files: { - src: ['*.php', '**/*.php', '!node_modules/**', '!tests/**', '!sample/**'] - } - } - }, - - // Generate POT files. - makepot: { - redux: { - options: { - type: 'wp-plugin', - domainPath: 'ReduxCore/languages', - potFilename: 'redux-framework.pot', - include: [], - exclude: [ - 'sample/.*' - ], - potHeaders: { - poedit: true, - 'report-msgid-bugs-to': 'https://github.com/ReduxFramework/ReduxFramework/issues', - 'language-team': 'LANGUAGE ' - } - } - } - }, - - // Check textdomain errors. - checktextdomain: { - options: { - keywords: [ - '__:1,2d', - '_e:1,2d', - '_x:1,2c,3d', - 'esc_html__:1,2d', - 'esc_html_e:1,2d', - 'esc_html_x:1,2c,3d', - 'esc_attr__:1,2d', - 'esc_attr_e:1,2d', - 'esc_attr_x:1,2c,3d', - '_ex:1,2c,3d', - '_n:1,2,4d', - '_nx:1,2,4c,5d', - '_n_noop:1,2,3d', - '_nx_noop:1,2,3c,4d' - ] - }, - redux: { - cwd: 'ReduxCore/', - options: { - text_domain: 'redux-framework', - }, - src: ['**/*.php'], - expand: true - }, - sample: { - cwd: 'sample', - options: { - text_domain: 'redux-framework-demo', - }, - src: ['**/*.php'], - expand: true - } - }, - - // Exec shell commands. - shell: { - options: { - stdout: true, - stderr: true - }, - // Limited to Maintainers so - // txpush: { - // command: 'tx push -s' // push the resources - // }, - txpull: { - command: 'tx pull -a --minimum-perc=25' // pull the .po files - } - }, - - // Generate MO files. - potomo: { - dist: { - options: { - poDel: true - }, - files: [{ - expand: true, - cwd: 'ReduxCore/languages/', - src: ['*.po'], - dest: 'ReduxCore/languages/', - ext: '.mo', - nonull: true - }] - } - }, - - phpdocumentor: { - options: { - directory: 'ReduxCore/', - target: 'docs/' - }, - generate: {} - }, - - phplint: { - options: { - swapPath: './' - }, - core: ["ReduxCore/**/*.php"], - plugin: ["class-redux-plugin.php", "index.php", "redux-framework.php"] - }, - - sass: { - fields: { - options: { - sourcemap: 'none', - style: 'compressed', - noCache: true, - }, - - files: [{ - expand: true, // Enable dynamic expansion. - cwd: 'ReduxCore/inc/fields', // Src matches are relative to this path. - src: ['**/*.scss'], // Actual pattern(s) to match. - dest: 'ReduxCore/inc/fields', // Destination path prefix. - ext: '.css' // Dest filepaths will have this extension. - }] - }, - extensions: { - options: { - sourcemap: 'none', - style: 'compressed', - noCache: true, - }, - - files: [{ - expand: true, // Enable dynamic expansion. - cwd: 'ReduxCore/inc/extensions', // Src matches are relative to this path. - src: ['**/*.scss'], // Actual pattern(s) to match. - dest: 'ReduxCore/inc/extensions', // Destination path prefix. - ext: '.css' // Dest filepaths will have this extension. - }] - }, - vendor: { - options: { - sourcemap: 'none', - style: 'compressed', - noCache: true - }, - - files: { - "ReduxCore/assets/css/vendor/jquery-ui-bootstrap/jquery-ui-1.10.0.custom.css": [ - "ReduxCore/assets/css/vendor/jquery-ui-bootstrap/jquery-ui-1.10.0.custom.scss" - ], - "ReduxCore/assets/css/vendor/elusive-icons/elusive-icons.css": [ - "ReduxCore/assets/css/vendor/elusive-icons/scss/elusive-icons.scss" - ], - } - }, - - admin: { - options: { - sourcemap: 'none', - style: 'compressed', - noCache: true - }, - - files: { - "ReduxCore/assets/css/color-picker/color-picker.css": [ - "ReduxCore/assets/css/color-picker/color-picker.scss" - ], - "ReduxCore/assets/css/media/media.css": [ - "ReduxCore/assets/css/media/media.scss" - ], - "ReduxCore/assets/css/redux-admin.css": [ - "ReduxCore/assets/css/redux-admin.scss" - ], - "ReduxCore/assets/css/rtl.css": [ - "ReduxCore/assets/css/rtl.scss" - ] - } - }, - welcome: { - options: { - sourcemap: 'none', - style: 'compressed', - noCache: true - }, - - files: { - "ReduxCore/inc/welcome/css/redux-welcome.css": [ - "ReduxCore/inc/welcome/css/redux-welcome.scss" - ] - } - } - }, - - cssmin: { - fields: { - files: { - 'ReduxCore/assets/css/redux-fields.css': [ - 'ReduxCore/inc/fields/**/*.css', - "ReduxCore/assets/css/color-picker/color-picker.css", - "ReduxCore/assets/css/media/media.css" - ] - } - }, - } - } - ); - - // Load NPM tasks to be used here - grunt.loadNpmTasks( 'grunt-shell' ); - grunt.loadNpmTasks( 'grunt-potomo' ); - grunt.loadNpmTasks( 'grunt-wp-i18n' ); - grunt.loadNpmTasks( 'grunt-checktextdomain' ); - grunt.loadNpmTasks( 'grunt-contrib-jshint' ); - grunt.loadNpmTasks( 'grunt-contrib-sass' ); - grunt.loadNpmTasks( 'grunt-contrib-uglify' ); - grunt.loadNpmTasks( 'grunt-contrib-watch' ); - grunt.loadNpmTasks( 'grunt-contrib-cssmin' ); - grunt.loadNpmTasks( 'grunt-contrib-concat' ); - grunt.loadNpmTasks( 'grunt-phpdocumentor' ); - grunt.loadNpmTasks( 'grunt-gh-pages' ); - grunt.loadNpmTasks( "grunt-phplint" ); - //grunt.loadNpmTasks( 'grunt-recess' ); - - grunt.registerTask( - 'langUpdate', [ - 'addtextdomain', - 'makepot', - 'shell:txpull', - 'potomo' - ] - ); - - // Default task(s). - grunt.registerTask( - 'default', [ - 'jshint', - 'concat:core', - 'uglify:core', - 'concat:vendor', - 'uglify:vendor', - 'uglify:fields', - 'uglify:extensions', - "sass:admin", - "sass:fields", - "sass:extensions", - "sass:vendor", - 'cssmin' - ] - ); - grunt.registerTask( 'travis', ['jshint', 'lintPHP'] ); - - // this would be run by typing "grunt test" on the command line - grunt.registerTask( 'testJS', ['jshint', 'concat:core', 'concat:vendor'] ); - - grunt.registerTask( 'watchUI', ['watch:ui'] ); - grunt.registerTask( 'watchPHP', ['watch:php', 'phplint:core', 'phplint:plugin'] ); - - grunt.registerTask( "lintPHP", ["phplint:plugin", "phplint:core"] ); - grunt.registerTask( "compileSCSS", ["sass:admin", "sass:fields", "sass:extensions", "sass:vendor", "sass:welcome"] ); - grunt.registerTask( - 'compileJS', - ['jshint', 'concat:core', 'uglify:core', 'concat:vendor', 'uglify:vendor', 'uglify:fields', 'uglify:extensions'] - ); - grunt.registerTask( 'compileTestJS', ['jshint', 'concat:core', 'concat:vendor'] ); - grunt.registerTask( 'compileCSS', ['cssmin'] ); -}; \ No newline at end of file diff --git a/library/admin/README.md b/library/admin/README.md deleted file mode 100644 index 5317677e..00000000 --- a/library/admin/README.md +++ /dev/null @@ -1,134 +0,0 @@ -## Redux Options Framework [![Build Status](https://travis-ci.org/reduxframework/redux-framework.png?branch=master)](https://travis-ci.org/reduxframework/redux-framework) [![Stories in Ready](https://badge.waffle.io/ReduxFramework/redux-framework.png?label=ready)](https://waffle.io/ReduxFramework/redux-framework) [![Built with Grunt](https://cdn.gruntjs.com/builtwith.png)](http://gruntjs.com/) - -WordPress options framework which uses the [WordPress Settings API](http://codex.wordpress.org/Settings_API "WordPress Settings API"), Custom Error/Validation Handling, Custom Field/Validation Types, and import/export functionality. - -## Posting Guidelines for issues and questions ## -When using our Issue Tracker, you may ask questions where you may be a bit lost or need help understanding the documentation. If, however, you find a bug we require you to read and provide the information contained in our [Contributing Guidelines](https://github.com/ReduxFramework/redux-framework/blob/master/CONTRIBUTING.md). If you do not provide this information, we will request it before we can support you. - -If you are stuck in some of your own code, or need help with PHP and anything else not Redux specific, we request you purchase some [Premium Support](http://reduxframework.com/extension/premium-support/) and we will be happy to assist you. If we feel the issue is outside of our scope we will suggest you to purchase some [Premium Support](http://reduxframework.com/extension/premium-support/) in order for us to serve you. - -## Kickstart Your Development ## - -Are you authoring a theme, or plugin? Visit the [Redux Builder](http://build.reduxframework.com) site and get started! - -## Demo Your Products ## -We help you create a seamless user experience for your users to demo your WordPress products. Not only that, we help you make sure they’re engaged, turning them into a potential customer. Visit [wpdemo.io/](http://wpdemo.io/) - -## Documentation ## - -Need a little help with Redux? Come check out our brand new documentation site at [docs.reduxframework.com](http://docs.reduxframework.com), chock full of tutorials and examples! - - -## SMOF (Simple Modified Option Users) Converter! ## - -Hot off the press, our Redux Converter plugin. It takes your SMOF instance, and allows you to try out Redux without any fear. It also spits out valid PHP source for you if you want to migrate complete with data migration! Give it a try today. It will be in the WordPress.org repo shortly. ;) -https://github.com/ReduxFramework/redux-converter - -## Help Us Translate Redux ## - -Please head over to the wiki to learn how you can help us translate Redux quickly. Any and all are welcome. We appreciate your help! -https://github.com/ReduxFramework/ReduxFramework/wiki/translate - -## Getting Started with Redux ## - -ReduxFramework has been built from the ground up to be the most flexible framework around. You can run it as an auto-updating plugin, or embed it inside your plugin or theme. It allows for multiple copies of itself within the same WordPress instance. For a guide on getting started please refer to [https://github.com/ReduxFramework/redux-framework/wiki/Getting-Started](https://github.com/ReduxFramework/redux-framework/wiki/Getting-Started). - -You can also [download our sample theme available here](https://github.com/ReduxFramework/ReduxSampleTheme) to start developing right away. - -## Please Post Reviews and Spread the Word ## - -ReduxFramework has just released to the WordPress Plugins directory. Please spread the word, tweet, and (most importantly) post reviews on http://wordpress.org/plugins/redux-framework/. - - -## Donate to the Framework ## - -If you can, please donate to help support the ongoing development of Redux Framework! - -[![Donate to the framework](https://www.paypalobjects.com/en_US/i/btn/btn_donateCC_LG.gif "Donate to the framework")](https://www.paypal.com/cgi-bin/webscr?cmd=_s-xclick&hosted_button_id=MMFMHWUPKHKPW) - -## Features ## - -* Uses the [WordPress Settings API](http://codex.wordpress.org/Settings_API "WordPress Settings API") -* Multiple built in field types -* Multple layout field types -* Fields can be overloaded with a callback function, for custom field types -* Easily extendable by creating Field Classes -* Built in Validation Classes -* Easily extendable by creating Validation Classes -* Custom Validation error handling, including error counts for each section, and custom styling for error fields -* Custom Validation warning handling, including warning counts for each section, and custom styling for warning fields -* Multiple Hook Points for customisation -* Import / Export Functionality - including cross site importing of settings -* Easily add page help through the class -* Fully responsive options panel -* Much more - -## Stay In The Loop! ## - -[![Follow us on Twitter](http://iod.unh.edu/Images/Twitter_follow_us.png "Follow us on Twitter")](https://www.twitter.com/ReduxFramework) - -## FAQs ## - -1. Why should we use ```require_once``` instead of ```get_template_part```? - * First, because ```get_template_part``` is for... you guessed it, themes! Redux is designed to work with both themes *and* plugins. - * Second, read [this](http://kovshenin.com/2013/get_template_part/). -2. Why shouldn't we edit ```sample-config.php``` in the plugin directory? - * Because ```sample-config.php``` will be replaced at each update of the plugin. You will lose all your effort - -## Are you using Redux? ## - -Send us an email at info@reduxframework.com so we can add you to our showcase! - -## Changelog ## - -See [Changelog.md](https://github.com/ReduxFramework/redux-framework/blob/master/CHANGELOG.md) - -## Running PHP Unit tests ## - -The tests are built using [wordpress's make subversion repository](https://make.wordpress.org/core/handbook/automated-testing/) - -`/var/www/wordpress-develop` as the destination for the core test files. -First download the wordress core tests repository, for these files. - -```bash -cd /var/www -svn co http://develop.svn.wordpress.org/trunk/ wordpress-develop -``` - -In the newly created `/var/www/wordpress-develop` directory rename -`wp-tests-config-sample.php` to `wp-tests-config.php`. Now add your database -details to the new file: -```php -// WARNING WARNING WARNING! -// These tests will DROP ALL TABLES in the database with the prefix named below. -// DO NOT use a production database or one that is shared with something else. - -define( 'DB_NAME', 'wordpress-tests' ); -define( 'DB_USER', 'root' ); -define( 'DB_PASSWORD', 'passowrd' ); -define( 'DB_HOST', 'localhost' ); -define( 'DB_CHARSET', 'utf8' ); -define( 'DB_COLLATE', '' ); -``` - - n.b. you may need to create the database first. - - n.b. n.b. also note that the database used will be emptied on each run. - -Set the `WP_TESTS_DIR` environment variable so that the `redux-framework` test bootstrap file can find the wordpress core tests: -```bash -export WP_TESTS_DIR='/var/www/wordpress-develop/tests/phpunit/includes/' -``` - -You should now be able to run the `redux-framework` unit tests: -```bash -redux-framework$ phpunit -Welcome to the TIVWP Test Suite -Version: 1.0 - -Tests folder: /var/www/wordpress-develop/tests/phpunit/includes/ - -Installing... -... -Configuration read from -redux-framework/phpunit.xml -... -``` \ No newline at end of file diff --git a/library/admin/README.txt b/library/admin/README.txt deleted file mode 100644 index 18dbaab6..00000000 --- a/library/admin/README.txt +++ /dev/null @@ -1,1129 +0,0 @@ -=== Redux Framework === -Contributors: dovyp, kprovance -Donate link: http://ideas.reduxframework.com -Tags: admin, admin interface, options, theme options, plugin options, options framework, settings, web fonts, google fonts -Requires at least: 3.5.1 -Tested up to: 4.3 -Stable tag: 3.5.6.1 -License: GPLv3 or later -License URI: http://www.gnu.org/licenses/gpl-3.0.html - -Redux is a simple, truly extensible and fully responsive options framework for WordPress themes and plugins. Ships with an integrated demo. - -== Description == - -Redux is a simple, truly extensible and fully responsive options framework for WordPress themes and plugins. Built on the WordPress Settings API, Redux supports a multitude of field types as well as: custom error handling, custom fields & validation types, and import/export functionality. - -But what does Redux actually DO? We don't believe that theme and plugin -developers should have to reinvent the wheel every time they start work on a -project. Redux is designed to simplify the development cycle by providing a -streamlined, extensible framework for developers to build on. Through a -simple, well-documented config file, third-party developers can build out an -options panel limited only by their own imagination in a fraction of the time -it would take to build from the ground up! - -= Online Demo = -Don't take our word for it, check out our online demo and try Redux without installing a thing! -[**http://demo.redux.io/**](http://demo.redux.io/) - -= Use the Redux Builder to Get Started = -Want to use Redux, but not sure what to do? Use our [builder](http://build.reduxframework.com/)! It will allow you to make -a custom theme based on [_s](http://underscores.me), [TGM](http://tgmpluginactivation.com), and [Redux](http://reduxframework.com), and any Redux arguments you want to set. -Don't want to make your own theme? Then output a custom admin folder that you can place -in a theme or plugin. Oh and did we mention it's free? Try it today at: -[**http://build.reduxframework.com/**](http://build.reduxframework.com/) - - -= Docs & Support = -We have extremely extensive docs. Please visit [http://docs.reduxframework.com/](http://docs.reduxframework.com/) If that doesn’t solve your concern, you should search [the issue tracker on Github](https://github.com/reduxframework/redux-framework/issues). If you can't locate any topics that pertain to your particular issue, [post a new issue](https://github.com/reduxframework/redux-framework/issues/new) for it. Before you submit an issue, please read [our contributing requirements](https://github.com/redux-framework/redux-framework/blob/master/CONTRIBUTING.md). We build off of the dev version and push to WordPress.org when all is confirmed stable and ready for release. - - -= Redux Framework Needs Your Support = -It is hard to continue development and support for this free plugin without contributions from users like you. If you enjoy using Redux Framework, and find it useful, please consider [making a donation](https://www.paypal.com/cgi-bin/webscr?cmd=_s-xclick&hosted_button_id=MMFMHWUPKHKPW). Your donation will help encourage and support the plugin's continued development and better user support. - -= Fields Types = - -* Background -* Border -* Button Set -* Checkbox / Multi-Check -* Color (WordPress Native) -* Color Gradient -* Color RGBA -* Date -* Dimensions (Height/Width) -* Divide (Divider) -* Editor (WordPress Native) -* Gallery (WordPress Native) -* Image Select (Patterns/Presets) -* Import/Export -* Info (Header/Notice) -* Link Color -* Media (WordPress Native) -* Multi-Text -* Password -* Radio (w/ WordPress Data) -* Raw (HTML/PHP/MarkDown) -* Section (Indent and Group Fields) -* Select (Select/Multi-Select w/ Select2 & WordPress Data) -* Select Image -* Slider (Drag a Handle) -* Slides (Multiple Images, Titles, and Descriptions) -* Sortable (Drag/Drop Checkbox/Input Fields) -* Sorter (Drag/Drop Manager - Works great for content blocks) -* Spacing (Margin/Padding/Absolute) -* Spinner -* Switch -* Text -* Textarea -* Typography - * The most advanced typography module complete with preview, Google fonts, and auto-css output! - -= Additional Features = - -* Field Validation -* MANY translations. (See below) -* Full value escaping. -* Required - Link visibility from parent fields. Set this to affect the visibility of the field on the parent's value. Fully nested with multiple required parents possible. -* Output CSS Automatically - Redux generates CSS and the appropriate Google Fonts stylesheets for you on select fields. You need only specify the CSS selector to apply the CSS to (limited to certain fields). -* Compiler integration! A custom hook runs when any fields with the argument `compile => true` are changed. -* Oh, and did we mention a fully integrated Google Webfonts setup that will make you so happy you'll want to cry? - - -= Translators & Non-English Speakers = -We need your help to translate Redux into your language! Redux is part of the WP-Translations.org team. To help us translate Redux create a few account here: https://www.transifex.com/organization/wp-translations. Once you're in, you can head over to the Redux sub-project and translate away. Thank you for your assistance. - -= Get Involved = -Redux is an ever-changing, living system. Want to stay up to date or -contribute? Subscribe to one of our mailing lists or join us on [Facebook](https://facebook.com/reduxframework) or [Twitter](https://twitter.com/reduxframework) or [Github](https://github.com/ReduxFramework/ReduxFramework)! - -NOTE: Redux is not intended to be used on its own. It requires a config file -provided by a third-party theme or plugin developer to actual do anything -cool! - -== Installation == - -= For Complete Documentation and Examples = -Visit: [http://docs.reduxframework.com/](http://docs.reduxframework.com/) - -== Frequently Asked Questions == - -= Why doesn't this plugin do anything? = - -Redux is an options framework... in other words, it's not designed to do anything on its own! You can however activate a demo mode to see how it works. - -= How can I learn more about Redux? = - -Visit our website at [http://reduxframework.com/](http://reduxframework.com/) - -= You don't have much content in this FAQ section = -That's because the real FAQ section is on our site! Please visit [http://docs.reduxframework.com/faq/](http://docs.reduxframework.com/faq/) - -== Screenshots == - -1. This is the demo mode of Redux Framework. Activate it and you will find a fully-functional admin panel that you can play with. On the Plugins page, beneath the description and an activated Redux Framework, you will find a Demo Mode link. Click that link to activate or deactivate the sample-config file Redux ships with. Don't take our word for it, check out our online demo and try Redux without installing a thing! [**http://demo.reduxframework.com/wp-admin/**](http://demo.reduxframework.com/wp-admin/) - -== Changelog == - -## 3.5.6.1 -* Fixed: Index error regarding icon argument. - -## 3.5.6 -* Fixed Customizer WP 4.3 final fixes. -* Fixed #2500 - Conflict with outdated select2 in JW Player plugin. -* Modified: icon_type no longer needed for section icons. Now detects if URLs are provided for images. -* Fixed: Various customizer fixes. HTML in the customizer title. -* Modified: Media URL now is 95% wide. -* Modified: Select2 now 100% width instead of just resolve (that doesn't always work). -* Modified: Field enqueue method to allow for more flexibility. -* Added: Support for Airplane Mode plugin (https://github.com/norcross/airplane-mode) by @norcross. Thanks @chriscct7 #2463 -* Fixed: Undefined index in theme-check enhancements. Thanks @winwinwebdesign! -* Removed: SASS compiler & code. Note needed. -* Fixed: Color transparency live-update for Customizer for color, background, - and color gradient fields. -* Fixed: Undefined index when removing a section. -* Fixed: Typography bug onload always saying settings have changed. -* Modified: Added minified customizer JS. -* Fixed: Redux CUSTOMIZER! YEA! -* Fixed: Small echo in Redux API - -= 3.5.5.1 = -* Fixed: Sigh, PHP 5.2 issues. - -= 3.5.5 = -* Fixed: Date-time fixes with CSS overloading and positioning. -* Added: Lite support for https://wordpress.org/plugins/plugin-dependencies/ -* Modified: CDN to be a more bulletproof solution (http://jsdelivr.net). -* Modified: CDN alerts to be more clear, and have proper links. -* Fixed: Bad code in raw field hosing up the entire panel. -* Modified: #2436 - Validation check for any validation type ending in 'not_empty' now recognized. -* Fixed: Undefined index for undeclared variable in Theme-Check checks. -* Fixed: Annoying Redux Theme-Check notices. -* Fixed: How some functions were called. -* Fixed: Theme-Check baby! Everything working as it should with extra theme-check hints to prepare - your theme for submission! -* Fixed: Better .org hinting for theme submission. -* Modified: `forced_dev_mode_off` argument that will ensure dev_mode is ALWAYS off. - PLEASE do not ship with this enabled. We will NOT provide any support for any instance that - has this argument enabled. Disable and test prior to posting on our issue tracker. -* Added: `customizer_only` as a global arg that disables all of Redux except for the customizer, in - preparation for our customizer integration. -* Modified: Dissmissable Redux Admin notices now use the WP 4.2 dismiss JS and Ajax. Pretty. -* Modified: Admin notice code is now it's own isolated class inside core. -* Modified: Use DB for admin notice, not flat-files. Boo. -* Modified: Sample configs not to cause errors if multiple users use the same function name. -* Fixed: CDN internationalization class. -* Modified: Parsedown so as not to throw a shortcode error that didn't actually exist. -* Fixed: #2446 - Non google font choice not saving in certain instances. -* Fixed: Added additional check in redux.js to stop errors with panels containing multiple raw fields. -* Fixed: Hopefully, the issue of settings not saving on first install when using the Redux API. -* Fixed: Set use_cdn argument to true, by default. -* Fixed #2437 - undefined value set to blank line height. -* Fixed: #2429 - Required evaluator 'contains' not working properly with multi_check -* Fixed: #2426 - Section field not indenting. -* Fixed: Divider field not rendering properly. -* Added: `fieldset_class` argument for fields. Thanks @Enchiridion. -* Added: Option to set checkbox label. Thanks @Enchiridion. -* Added: javascript .trigger('change') to switch, spinner, and image_select. Thanks @Enchiridion. -* Modified: Ajax change output of error and notice via hooks. -* Fixed: #2414 - Bad ajax save due to mis-initialized variable. -* Fixed: CSS in metabox fields all wanky. -* Added: 'reload_on_change' arg for fields, to force page reload after setting change. -* Fixed: #2377 - Replaced mysql_gets_server_info with $wpdb. -* Modified: Templates to properly excape values. -* Fixed: Import/Export to properly be full-width and use lazy-load JS. -* Modified: CSS for sections to bound to the section, not all of Redux. -* Fixed: #2368 - Options panel layout offset. -* Fixed: #2369 - validate_callback not working for color, color_gradient, and date. -* Fixed: #2355 - Space missing in switch class arg. -* Fixed: Fixed all fields without leading space in class arg. -* Modified: Restrict table modification to redux-container. -* Fixed: Container overflow for pre's. -* Modified: Redux API to include removeSection and removeField. -* Added: Added before and after hooks to any panel template file. -* Fixed: #2351 - WP_Error check added to admin blast remote get. -* Modified: Moved styling for the divide field into it's own CSS file. -* Modified: All WP Color Pickers to properly save the value before save. -* Added: CSS Styles for the customizer. ;) -* Modified: Panel is MUCH more responsive now. -* Fixed: Small stylings for a few fields. -* Fixed: Added extra qTip class. -* Modified: Ajax save animation. Added fallback for pre 4.2 CSS. -* Fixed: Small issue with Redux info boxes and spacing. -* Fixed: Small bug with the Redux API where divide sections were causing errors. -* Fixed: Small admin blast fix. -* Modified: Qtip and Spectrum vendor libraries restored to local. -* Fixed: Admin notice loading on front end. -* Modified: Callback actions run with do_action_ref_array now. -* Added: show_options_object argument to enable or disable option object. -* Added: Error suppressing to filesystem class to avoid notice errors when site goes down. -* Fixed: Panels not rendering, again -* Added: Vendor support plugin link to CDN fallback message. -* Modified: Moved vendor libraries ACE, select2, qtip, and spectrum to CDN. -* Removed: Local installs of above libraries. -* Fixed: Option panel not rendering due to experimental code. -* Fixed: How sorter works with data -* Modified: How the data arg is stored in Redux. -* Removed: sysinfo.php. No longer needed in lieu of our support URL feature. -* Removed: debug.php. Moved to options_object extension. -* Modified: #2274 - PHP Unit test compatibility. Thanks @daithi-coombes. -* Modified: #2144 - Optional class argument per image. Thanks @paulthecoder. -* Fixed: #2278 - More W3 Total Cache hacks. - -= 3.5.4.3 = -* Fixed: #2258 - welcome redirect error with embedding plugin scenarios. -* Fixed: Redux plugin load order when activating plugins. -* Fixed: #2271 - stuck redirect on godaddy (seriously, get a real host, people) servers. -* Fixed: #2216 - Reset section not always working within FF. - -= 3.5.4 = -* Modified: update_notice arg only truly shows up if dev_mode is on. -* Added: Tooltip to developer mode badge, for informational purposes. -* Modified: Added css_layout ext to default value filter, to avoid errors. -* Fixed: #2239 - Various extensions didn't support default values for default arg. Filtered out offending extensions. - -= 3.5.3.1 = -* Fixed: WP.org ONLY SVN mixup. - -= 3.5.3 = -* Fixed: #2228 - Submenu items still visible if permissions not allowed. -* Fixed: Import/Export showing up in customizer. -* Modified: Admin-fresh theme to match new WordPress 4.2 -* Modified: Redux widget now has a proper ID. Thanks @corradomatt! -* Modified: Added text-shadow to submenu items to give a stronger "pop" -* Modified: Page_slug now dynamically generated if not specified. -* Modified: Admin blast message pinging server on each load after three day expiration. Possible slow down of the overall panel loading time. -* Fixed: #2221 - Background field media not enqueueing when used with no other media based fields. -* Fixed: #2214: Bad path for import/export enqueue. -* Release: Wp.org release. -* Fixed: #2214 - Import/export field contained bad enqueue path. -* Modified: If running localhost or WP_DEBUG is set to true, Redux dev_mode is forced to true. -* Modified: Page_slug now dynamically generated if not specified. - -= 3.5.1 = -* Modified: Redux News dashboard widget appears only when dev_mode is true or in a local host environment. -* Fixed #2127 - Elusive icons not working in footer as before. -* Fixed Issue where Status tab not showing extension versions properly. -* Fixed Issue in support URL not passing data correctly. -* Fixed Support URLs now work even if max_input_vars is way low in PHP 5.3+ -* Fixed #2197 - Import/export not loading proper for those who have opted to install Wordpress in ways it was never intended. -* Fixed: 'Generate Support URL' feature kicking back error. -* Fixed Sortable checkbox labels not displaying properly. -* Fixed Sortable textbox not displaying default value as placeholder. -* Updated: sample-config with accurate example for both sortable modes. -* Fixed #2181 - Fixed issue with Ajax Save when PHP 5.3 Magic Quotes were disabled. -* Fixed: #2181 - Lingering issue with Ajax Save and PHP Magic Quotes. - -= 3.5.0 = -* Fixed: #2181 - Issue with PHP < 5.4 and the Ace Editor field. Oy. -* Fixed: #2163 - Undefined error in JS. -* Fixed: #2176 - Infinite loop in the customizer for live preview of themes. -* Fixed: Support page now works. -* Fixed: Fix for MySQL deprecated functions in php 5.5+. -* Added: Dynamic admin messages (aka Newsflash). Dismissable admin messages announcing breaking Redux news. - Messages will not appear for users when dev_mode is set to `false`. However, messages remain active - on localhosts, so devs may benefit. -* Fixed: #2155 - Fixed import with ajax_save. -* Fixed: Changelog now uses raw field parsedown if present. -* Added: Redux Framework News Widget on the WP Dashboard. -* Fixed: #2156: `label` argument not recognized when using sortable as textbox. -* Fixed: #2140 Another PHP 5.2 issue with ajax_save. -* Modified: Opt groups for select field now working in customizer even if not supported. -* Added: `full_width` arg now makes ANY field full-width. :) -* Fixed: #2133 - Ajax save adding extra backspashes in PHP 5.2 only (They didn't use array map properly). -* Fixed: Customizer wasn't working. Thanks @sgssandhu! -* Fixed: #2125 - Compiler not firing on first save, when using ajax_save. -* Fixed: #2118 - Typography JS error. -* Fixed: Odd typography bug no one has reported. -* Modified: Sticky header and footer to remain within the redux-main container. -* Fixed #2097 - Slash fix for ajax_save that was previously believed to be an isolated issue. Now applied on all ajax saves. -* Fixed: #2086 - color_rgba improperly functioning when transparent mode set to false. -* Fixed Import/Export bug where it wasn't running. -* Modified Locations of the core extensions directory as well as grunt configuration. -* Fixed #2047 - Validation will now accept 0 as a value to be tested. Thanks @Ninos! -* Added url_slug validation with option flush_permalinks! -* Fixed Issue where the remove of background field was always showing an empty preview box. -* Modified Turned ajax_save on by default for additional bug reports. ;) -* Modified Added some margin above validation errors/warnings so they look better. -* Modified Removed previous element border for any section so it looks better. -* Fixed #2081 - Section field hiding any field after. Weird. -* Added #2047 - `output_transparent` argument to output the blank color feature as 'transparent'. -* Fixed #2080 - missing 'rem' unit and inability to process float values. Thanks to @HELWATANY for the fixes! -* Fixed #2043 - misaligned images in image_select field. -* Added: #2064 - Merge argument for image_select. Thanks @Ninos -* Modified: Import/Export is now an extensiona and decoupled from the core. -* Fixed: Spinner had a nasty number bug, now resolved. -* Fixed: #2076 - RTL bug with old ID's. Thanks @mahfoozroy. -* Fixed: #2072 - Ajax_save editor type bug fix. -* Fixed: #2058 - Incorrect path in include statement for sysinfo.php -* Modified: Templates now have versioning with a warning (dev_mode only) if they are outdated from the core templates. -* Modified: Ajax saving now has overlay during save to avoid confusion for users. -* Modified: Template files even more for simplicity and ease. -* Modified: Saving. Redux now has the ajax_save argument if you want it! -* Modified: Validation warnings now work. -* Fixed: Changed set_transient function to public to avoid errors in new templating code. -* Modified: Entire panel template is now decoupled from the theme and implemented with many filters for easy customization. -* Fixed: #1478 - Import/export failing when two instances if Redux in use. Thanks, @desaiuditd! -* Fixed: Section field not indenting properly, if at all. -* Added: #2031 - Proper CSS sanitization for compliancy with WP.org. -* Fixed: #2027 - added isset() -* Fixed: #2019 - Reset issues with PHP 5.2. Thanks a bunch, @Webcreations907! -* Fixed: #2023: Issue with custom submenus in menu. -* Fixed: #2025: Issue with select sorting. -* Update: ACE Editor. Thanks @corradomatt. - -= 3.4.1 = -* Fixed: Small filesystem option with bad filter key reference.. -* Added: Small return if $section filter returned the section empty. - -= 3.4.0 = -* Fixed: Reset section hook firing too early. -* Modified: The Redux Repeater field has landed! -* Fixed: #1983 - color_rgba not outputting default values on first load (before save). -* Fixed: Google font enqueues with opt_name to avoid collision with multiple Redux instances. -* Fixed: #1980 - JS errors with sorter & sortable. -* Fixed: color_rgba field outputting incorrect information via output/compiler. -* Fixed: #1979 - Goole fonts not properly loading in typography dropdown. -* Fixed: Undefined index error on MU installs. -* Removed: SASS compile of field CSS, for the time being. Compiler remains in core. -* Improved: Panel load time, most notable when not in dev_mode. Better for your clients. :) -* Updated: Elusive Font library. -* Fixed: #1961 - color_rgba field defaulting to black on reset. -* Fixed: #1941 - Datepicker opened off screen. -* Fixed: #1756, #1957 - Slider issues. Thanks @FFIN! -* Fixed: #1960 - Duplicate slide when clicking Add. Again, thanks to @FFIN for the fix. -* Added: New filter: apply_filters 'redux/validate/{opt_name}/before_validation' -* Fixed: #1745 - Adding settings submenu to empty submenu now works. Many, many thanks to @No3x for cracking this one! -* Fixed: #1955 - Undefined index rgba in output routine. -* Modified: #1947 - Added display:none to TR tag under info field. -* Replaced: #1951 - Replaced develop branch of scssphp to master branch due to PHP 5.2 incompatibililty. -* Fixed: #1943 - Removed premature DIV close. -* Fixed: #1945 - Media preview not rendering when default ID specified. -* Modified: #1930 - reorder 'psedo-class of link_color field. Thanks @freddessaint -* Modified: SASS compiler outputs to page by default. Faster. -* Fixed: #1927 - Incorrect dir path to spectrum library in color_rgba field corrected. -* Modified: color_rgba field now usees spectrum color picker. minicolors removed. Just...too buggy. -* Modified: #1922 - Filesystem output function. -* Fixed: Added PHP 5.2 support (ugh!) for SASS compiler. -* Fixed: More SASS compiler tweaking. -* Fixed: PHP errors when disabling SASS. -* Fixed #1909 - malformed DIV class HTML in slider field. -* Removed Argument for SASS compile file output location removed. Didn't work, too much trouble. -* Fixed: #1904 - select_image field not displaying saved value on page reload. -* Fixed: SASS compile under multi-instance outputting incorrect CSS file -* Fixed: redux-admin scss images converted to base64 -* Added SASS compiler for admin CSS. -* Added SASS to CSS for grunt compiler. -* Added SASS compiler for fields. -* Updated: select2 3.5.2 -* Fixed: #1856 - Illegal offset string warnings in framework.php. Thanks @CGlingener. -* Fixed: #1874 - Required operator 'contains' and 'not_contains' not working with select set to multi. -* Fixed: #1829 - Required operator '=' and '!=' not working with select set to multi. -* Fixed: #1870 - Border field doubling up on px in output/compiler. -* Added: `hidden` argument for fields. -* Added: `hidden` argument for sections. -* Fixed: #1868 - Improper panel render when opening expanded, when `open_expanded` set to true. -* Added: `hide_expand` argument, to hide the expand options button. -* Fixed: #1865 - Sortable select not saving proper order. -* Fixed: #1864 - Footer z-index CSS adjusted. -* Fixed: #1848 - Import-export filed buttons not functioning properly. -* Fixed: #1834 - Wordpress data dealing with IDs as array keys not rendering properly. -* Fixed: #1830 - Font lists were added in quotes. Thanks @karimhossenbux. -* Fixed: #1798 - Fixed lazy load JS to only load visible sections. Much more optimized. -* Fixed: #1821 - Exo 2 font not working, issue with typography and escaping. -* Added: #1803 - Optgroup support for select field. -* Added: Decimal increments to spinner. - -= 3.3.9.4 = -* Added: Customizer now supports PANEL! Yay 4.0. -* Fixed: #1789 - Customizer now properly working again with WP 4.0. Odd bug. - -= 3.3.9.2 = -* Fixed: #1670 - Fixed some extra themecheck and customizer issues. -* Fixed: #1782 - Media field not showing files after upload? Hopefully this fixes it. - -= 3.3.9 = -* Fixed: #1775 - Call to undefined function is_customize_preview() in pre WP 4.0. -* Fixed: Issue where in some cases tracking still occuring after opt-out. -* Modified: Documentation URL. -* Fixed: #1742 - Sidebar subsections don't always expand. -* Fixed: #1758 - Thanks @echo1consulting! -* Added: 'hidden' to menu_type argument to allow for hidden menus until available. -* Fixed: #1749 - Remove font-wight and font-style from css output when not in use. -* Modified: Added the "redux/options/{$this->args['opt_name']}/compiler/advanced" hook for more advanced compiling. -* Added: Suggestions as per #1709. Thanks @echo1consulting. -* Modified: Removed a cURL instance from the core and fixed the developer ad resizing. -* Fixed: PHP 5.2 issues. *sigh* - -= 3.3.8.3 = -* Added: #1593 - Great pull request by @JonasDoebertin. Now you can enqueue dynamic output to the login screen or admin backend. -* Fixed: Customizer wasn't saving at all! That's been like 4 months. No one's reported it. Hmm. -* Fixed: #1702 - Customizer only fields were being erased on panel save. -* Fixed: Various Theme-Check errors with languages. -* Added: Theme-Check class to help devs know what is what. -* Fixed: The way we include files from include_once to require_once everywhere. -* Modified: Language files to reflect new strings. -* Modified: Formatted a bunch of old class files. -* Added: Notice on the updates for non-devs to use the new dev_mode disabler plugin and notify their developer. ;) - -= 3.3.8 = -* Modified: Updated potomo, thanks @shivapoudel. -* Added: Grunt checktextdomain and made improvements. Thanks @shivapoudel. -* Modified: #1685 - Specifying no default argument for image_select caused errors on reset. -* Fixed: #1667 - Slides Upload button causing JS error. -* Fixed: #1670 - Fix for Theme Check -> `add_setting() method needs to have a sanitization callback function passed.` -* Fixed: #1661 - Fix for undefined index in some versions of PHP. Thanks @gianbalex! -* Modified: #1658 - Improvements from @shivapoudel, including: - * Removed makepot and used grunt-wp-i18n instead. - * Added a jshintrc file - * Added a `grunt addtextdomain` to correct any bad textdomains in the core. - * Updated .gitignore for better readability - * Updates to a few other files including package.json. - * Updated language files. - * Update codestyles/.editorconfig to reflect the project's standards. -* Modified: #1653 - Better admin bar with external links: Admin bar menu priority, icon, and external links. Thanks @shivapoudel! -* Added: #1651 - `library_filter` argument. Allows specification of what files to display in the media library. -* Modified: #1651 - `mode` argument accepts either file type or mime type (but not both). -* Fixed: #1650 - Toogle error with responsive CSS. -* Fixed: #1643 - Slight border issue (2px) on sticky footer. -* Fixed: #1642 - Added `font_family_clear` arg, enabling the clear option for font-family. -* Fixed: #1638 - Spacing field not outputting when units values attached to default values. -* Modified #1644 - `import_icon` argument now accepts wordpress dashicons -* Fixed: #1634 - Double border for sections field. Thanks @AlexandruDoda -* Modified: Changelog location to now Changelog.md. -* Fixed: #1632 - Sortable with no defaults set revert to false (instead of options values). -* Fixed: Labels for sortable in text mode updated to match framework. - -= 3.3.7 = -* Added: #1586 - Class-level declaration for callbacks and validation. Thanks @echo1consulting. -* Modified: Typography field now fully dynamic. -* Modified: No longer require a google_api_key for the typography module. :) -* Fixed: FTP credentials screen giving a "undefined submit_button function". Resolved. -* Fixed: #1623 - Registered older noUISlider JS under a new name to avoid conflicts. -* Modified: #1622 - Removed googlefonts.js dependency. -* Modified: #1628 - Spacing and dimensions now only output 0 if the entry is a 0, not empty. - Thanks @Webcreations907 -* Modified: CSS for menu items when active (no hover). -* Added: Visual feedback to left menu if active. - -= 3.3.6.8 = -* Fixed: #1600 - ACE Editor bombing in PHP 5.2 environments. -* Fixed: #1591 - Erroneous outputting of font-weight and font-style when no font-family selected. -* Updated: #1569 - Improved submenu highlighting. -* Added: #1487 - Added `get_default_value` function into the framework.php -* Fixed: Framework URI errors when using child themes. Some restructuring. -* Fixed: Framework URI errors when embedded in theme with Windows. -* Added: image_size as an option for the data argument. Thanks @Gyroscopic! -* Modified: How Redux paths are run. Should cover all use cases now. Child themes can also embed - Redux properly now. Thanks @cfoellmann for the suggestions. Fix for issue #1566. -* Modified: How we declare the uploads directory and URL. Using core WP functions now. -* Modified: Now if a section is empty, but has subsections, that section will be "skipped" when - clicked and the first subsection will then be shown. - -= 3.3.6 = -* Fixed: #1560 - IE8 RGBA fallack -* Modified: Language files. -* Fixed: #1543 - Hint icon not changing when set in args. -* Fixed: #1537 - Media field not accepting images with mode set to false. -* Fixed: #1529 - ACE Editor conflict with Visual Composer. -* Added: #1530 - Added argument to specify admin bar icon, `admin_bar_icon`. Thanks Ninos! -* Fixed: #1532 - Media field not accepting any mime type when `'mode' => false`. -* Fixed: #1520 - Checkbox field not displaying Wordpress data when using data argument. -* Fixed: #1516 - Invalid index and foreach when using compiler and async_typography. -* Fixed: #1509 - Sorter adding unnecessary bits on some items. -* Fixed: #1514 - Customizer and multisite not getting on properly. -* Fixed: #1512 - Slides 'Upload' button not showing or saving selected image. -* Fixed: Checkboxes with required were working in reverse. -* Fixed: ASync Typography now works! No more flashing fonts. -* Fixed: #1489 - Color picker UI lining up improperly. -* Fixed: #1497 - dev_mode spinner issue. -* Fixed: Spelling error in tracking dialog. -* Modified: Updated ace_editor. -* Modified: Many MANY fields for the group field. -* Fixed: Some CSS bugs. -* Fixed: #1481 - Custom fonts loading in google font CSS. -* Fixed: #1485 - Customizer 'invalid argument' error. Thanks @rnlmedia. -* Fixed: #1472 - font style not displaying saved valie with no font-family argument set. -* Fixed: #1471 - raw field and required not playing nice together. - -= 3.3.5 = -* Added: An annoying notice at the top so our devs don't ship with dev_mode on. ;) - -= 3.3.4.9 = -* Fixed: #1462 - Google fonts not loading in font drop down. - -= 3.3.4.8 = -* Fixed: More WP FileSystem tanking. Did PHP fallback before FTP. Works 99.9% of the time without credentials. - -= 3.3.4.7 = -* Fixed: Incorrect folder CHMOD in filesystem class. - -= 3.3.4.6 = -* Fixed: #1454 - Chmod permissions for redux folder. - -= 3.3.4.5 = -* Fixed: #1451 - Googlefonts not loading due to failing copy function. - -= 3.3.4.4 = -* Fixed: #1450 - Saves witch values with no `on` or `off` args make the core unhappy. - -= 3.3.4.3 = -* Fixed: #1444, again, due to filesystem growing pains. -* Fixed: #1449 - Restoring `options` argument over a lousy attempt to fix placeholder. - -= 3.3.4.2 = -* Fixed: More file permission issues. - -= 3.3.4.1 = -* Fixed: Font debug was left from last commit. Sorry all. - -= 3.3.4 = -* Fixed: Issues with file writing. Basically many users don't install WordPress with all the permissions - correct. So... Had to move it back to ~/uploads/. Sorry Otto, that's just how it is. -* Fixed: #1444 - output of typography all_styles when font_style UI was hidden. -* Fixed: #1440 - flaw in new cleanFilePath logic. -* Fixed: #1432 - Theme check failing when double-slashes existed in get_template_directory() return. -* Removed: curlRead from helper class. -* Fixed: #1426 - menu_name not appearing on front end admin bar. -* Added: #1427 - button_set added to customizer UI. Thanks @wpexplorer. -* Fixed: #1429 - ACE Editor erroring with no default value set. -* Fixed: wp_filesystem now initialized with credentials in an effort to combat the tmp file issue. -* Modified: Code purification. -* Modified: How section tabs work. Isolated within the redux-container class. -* Modified: #1412 - Redesigned text label, placeholder fix. - -= 3.3.3 = -* Fixed: #1408 & #1357 - Typography subsets losing value after multiple saves on other panels. -* Fixed: #1403 - unit value no longer prints after empty typography values -* Modified: Typography: Backup font no longer appends to `font-family` variable. Please use the - `backup-font` variable to specify backup fonts. This does not apply to output/compiler strings. -* Fixed: #1403 - Backup font not appearing in font-family variable. -* Modified: Customizer now supports section and field `permissions` argument. -* Fixed: #1399 - Customizer respects `page_permissions` argument. -* Fixed: #1400 - output/compiler string incomplete using multiple selectors. -* Fixed: #1396 - Custom fonts cutting off multiple families in selector, after save. -* Fixed: Typography attempting to queue up non google fonts on backend. -* Added: #1395 - Display of child theme status in sysinfo, thanks @SiR-DanieL. -* Fixed: #1387 - Page jump when clicking "Options Object". Thanks @rrikesh. -* Added: #1392 - Filters to change the following localized strings: - redux/{opt_name}/localize/reset - redux/{opt_name}/localize/reset_all - redux/{opt_name}/localize/save_pending - redux/{opt_name}/localize/preset -* Fixed: #1376 - checkbox.min.js missing. -* Fixed: Static variable changes for instances and basic comment cleanup -* Fixed: #1361 - Raw field not hiding with required. -* Fixed: Datepicker not formatting properly. Still needs some work. - - -= 3.3.2 = -* Fixed: #1357 - Preview not rendering font on page load. -* Fixed: #1356 - Color fields and transparency not syncing due to new JS. -* Fixed: #1354 - Add class check for W3_ObjectCache. -* Fixed: #1341 - JS not initializing properly in import_export. -* Fixed: #1339 - Typography would lose Font Weight and Style. value was named val in the - HTML, so it would be destroyed on the next save if not initialized. -* Fixed: #1226 - W3 Total Cache was affecting validation and compiler hooks. -* Fixed: Menu errors weren't showing properly for non-subsectioned items. -* Fixed: #1341 - Import/Export buttons not functioning. Also fixed sortable somehow. -* Fixed: Slides not initializing with the last fix. -* Fixed: Slides field was not properly initialized for the media elements. Fixed. - -= 3.3.1 = -* Fixed: #1337 - `redux` JS dependency loading issue. Many thanks @tpaksu -* Modified: Drastically changed the way JavaScript is used in the panel. Forced as-needed - initialization of fields. Thus reducing dramatically the overall load time of - the panel. The effects have been seen up to 300% speed improvement. The only - time a field will be initialized is if it's visible, thus reducing the processing - needed in DOM overall. -* Fixed: #1336 - fixed default font in preview. -* Fixed: #1334 - Typography not un-saving italics. -* Added: #1332 - New validation: numeric_not_empty. -* Fixed: #1330 - Required not working on all fields. - -= 3.3.0 = -* Fixed: #1322 - Sections not folding with required argument. -* Fixed: #1270 - Editor field compiler hook not firing in visual mode. -* Fixed: select2 dependency in select_image, and other fields. -* Fixed: Filter out `@eaDir` directories in extensions folder. -* Fixed: Fixed the image_select presets to work again. Also now will function even if import/export is disabled. -* Fixed: Minor tweaks for metabox update. -* Fixed: #1297 - Missing space in image_select class. -* Fixed: Slider field tweaked for metaboxes. -* Fixed: #1291 - Change of font-family would not trigger preview, or show in open preview. -* Fixed: #1289 - Typography not retaining size/height/spacing/word/letter spacing settings. -* Fixed: #1288 - Background color-picker dependency missing. Thanks @farhanwazir. -* Fixed: Search extension failed do to dependency issue from the core. -* Fixed: #1281 - color field output/compiler outputting incorrect selector when only one array present. -* Fixed: Update check only appears once if multiple instances of Redux are loaded in the same wordpress instance. -* Fixed: Changing font-family in typography didn't trigger 'save changes' notification. -* Fixed: More typography: Back up font appearing in font-family when opening selector. -* Fixed: Typography: undefined message when NOT using google fonts. Thanks @farhanwazir -* Fixed: Typography font backup not in sync with font-family. -* Fixed: Typography not saving font-family after switching back and forth between standard and google fonts. -* Fixed: Background field selects not properly aligned. -* Fixed: Removed select field dependency from background field. -* Fixed: #1264 - Color-picker/transparent checkbox functionality. -* Fixed: Typography fine-tuning. -* Fixed: All typography select fields render as select2. -* Fixed: Switching between transparency on and off now restores the last chosen color in all color fields. -* Fixed: Redux uploads dir should NOT be ~/wp-content/uploads, but just wp-content. As per Otto. -* Fixed: Navigation no longer has that annoying outline around the links. Yuk. -* Fixed: #1218 - Select2 multi select not accepting any keyboard input. -* Fixed: #1228 - CSS fixes -* Added: `hide_reset` argument, to hide the Reset All and Reset Section buttons. -* Added: `content_title` argument to slides field. Thanks @psaikali! -* Added: `customizer_only` argument for fields & sections, contributed by @andreilupu. -* Added: select2 args for spacing field. -* Added: select2 args for the following fields: typography, background, border, dimensions and slider. -* Added: #1329 - `'preview' = array('always_display' => true)` argument to typography, to determine if - preview field show always be shown. -* Modified: Portions of core javascript rewritten into object code. -* Modified: All field javascript rewritten using jQuery objects (versus standard function). -* Modified: Typography field rewritten to fill out font-family field dynamically, versus on page load. - -= 3.2.9.13 = -* Modified data => taxonomies now has a little more power behind it. -* Fixed: #1255 - button_set multi field not saving when all buttons not selected. -* Fixed: #1254 - Border field with 0px not outputting properly. -* Fixed: #1250 - Typography preview font-size not set in preview. -* Fixed: #1247 - Spacing field not outputting properly in `absolute` mode. -* Modified: Typography previewing hidden until font inputs are changed. -* Fixed: Vendor js not loading properly when dev_mode = true -* Fixed: Border field not outputting properly. -* Modified: Centralized import/export code in anticipation of new builder features. -* Fixed: Removed rogue echo statement. -* Modified: select2 loads only when a field requires it. -* Modified: More code to load JS on demand for fields require it. -* Modified: Field specific JS only loads with active field. -* Fixed: Hints stopped working due to classname change. -* Fixed: Permissions argument on section array not filtering out raw field. -* Fixed: Too many CSS tweaks to list, due to last build. -* Fixed: Sortable and Sorter fields now sort without page scroll when page size is under 782px. -* Fixed: Hint icon defaults to left position when screen size is under 782px. -* Fixed: `permissions` argument for fields and sections erasing saved field data. See #1231 -* Modified: Woohoo! Nearly fully responsive. Yanked out all SMOF and NHP field customizations. Lots of little - fixes on all browser screens. This will also greatly benefit Metaboxes and other areas of Redux. -* Fixed: In dev_mode panel CSS was being loaded 2x. -* Fixed: Typography color picker bleeding under other elements. #1225 -* Fixed: Hint icon_color index error from builder. #1222 - -= 3.2.9 = -* Added: Network admin support! Set argument 'database' to network and data will be saved site-wide. Also - two new arguments: network_admin & network_sites for where to show the panel. -* Added: Customizer hook that can be used to simulate the customizer for live preview in the customizer. - `redux/customizer/live_preview` -* Added: `output` argument for `color` and `color_rgba` fields accepts key/pairs for different modes. -* Added: `class` argument to the Redux Arguments, section array, and metabox array. If set, a class will - be appended to whichever level is used. This allows further customization for our users. -* Added: disable_save_warn flags to the arguments to disable the "you should save" slidedown. -* Added: Actions hooks for errors and warnings. -* Fixed: Redux now ignores any directories that begin with `.` in the extension folder. See #1213. -* Fixed: Redux not saving when validating uploads. -* Fixed: Border field output/compiler formatting. Removed 'inherit' in place of default values. See #1208. -* Fixed: Trim() warning in framework.php when saving. See #1209, #1201. -* Fixed: Typography not outputting all styles when `all_styles` set to true. -* Fixed: 'Cannot send header' issues with typography. -* Fixed: Small fix for validation if subsection parent is free of errors, remove the red highlight when not - expanded. -* Fixed: Small CSS classes for flashing fonts where web-font-loader. -* Fixed: ASync Flash on fonts. FINALLY. What a pain. -* Fixed: 3+ JavaScript errors found in the background field. Now works flawlessly. -* Fixed: PHP warnings in background field. #1173. Thanks, @abossola. -* Fixed: CSS validation not respecting child selector symbol. #1162 -* Fixed: Extra check for typography bug. -* Fixed: Error css alignment issue with subsections. -* Fixed: javascript error in typography field. -* Fixed: Added a title to the google fonts stylesheet to fix validation errors. -* Fixed: One more slides field error check, and an extra JS goodie for an extension. -* Fixed: Leftover debug code messing up slides field. -* Fixed: More reliable saved action hook. -* Fixed: Removed erroneous debug output in link_color field. -* Modified: Dimension field default now accepts either `units` or `unit`. -* Modified: Google CSS moved into HEAD via WP enqueue. -* Modified: Now do a trim on all fields before validating. No need to alert because of a space... -* Modified: Typography field CSS completely rewritten. All thanks to @eplanetdesign! -* Modified: Validation now works in metaboxes as well as updates numbers as changes occur. Validation for - subsections is SO hot now. -* Modified: Various CSS fixes and improvements. -* Modified: Turned of mod_rewrite check. -* Modified: How errors are displayed, no longer dependent on the ID, now proper classes. -* Modified: Error notice stays until all errors are gone. Also updates it's number as errors fixed! -* Modified: Moved google font files to proprietary folder in upload to help with permission issues. - -= 3.2.8 = -* Fixed: Formatting of field files. Normalizing headers. -* Added: is_empty / empty / !isset AND not_empty / !empty / isset as required operations -* Fixed: Reset defaults error. -* Added: `show` argument to turn on and off input boxes in slider. -* Fixed: Required now works with muti-check fields and button set when set to multi. - -= 3.2.7 = -* Fixed: Import works again. A single line was missed... -* Fixed: link_color field not outputting CSS properly via compiler or output. Thanks @vertigo7x -* Fixed: Sorter field CSS. Buttons were all smushed together. -* Fixed: 'undefined' error in typography.js. Thanks @ksere. - -= 3.2.6 = -* Fixed: Another stray undefined index. Oy. -* Added: `open_expanded` argument to start the panel completely expanded initially. - -= 3.2.5 = -* Fixed: Various bad mistakes. Oy. - -= 3.2.4 = -* Fixed: Slight typography speed improvement. Less HTML hopefully faster page loads. -* Fixed: Unload error on first load if the typography defaults are not set. -* Fixed: Errors pertaining to mod_rewrite check. -* Fixed: All those headers already set errors. -* Added: $changed_values variable to save hooks denoting the old values on a save. -* Added: Pointers to Extensions on load. -* Modified: CSS Output for the background field. -* Fixed: Validation error messages not appearing on save. -* Modified: Speed boost on validation types. -* Added: Apache mod_rewrite check. This should solve many issues we've been seeing regarding mod_rewrite - not being enabled. -* Fixed: Sortable field not saving properly. -* Fixed: Erroneous data in admin.less -* Updated: sample-config.php. Sortable checkbox field example now uses true/false instead of text meant for - textbox example. - -= 3.2.3 = -* Fixed: Responsive issues with spacing and dimension fields. -* Fixed: Style conflicts with WP 3.9. Added register filter to fields via id. -* Fixed: Metaboxes issues. -* Fixed: Compiler hook in the customizer now passes the CSS. -* Fixed: Compiler hook now properly fires in the customizer. -* Fixed: Validation error with headers already being set. -* Fixed: Added mode for width/height to override dimensions css output. -* Fixed: Restoring lost formatting from multiple merges. -* Fixed: New sorter default values get set properly now. ;) -* Fixed: Removed erroneous 's' character from HTML. -* Fixed: Info field didn't intend within section. -* Fixed: Compiler hook wasn't running. -* Modified: Some admin panel stylings. Now perfect with mobile hover. Also fixed an issue with the slidedown - width for sections. No more 2 empty pixels. -* Added: `data` and `args` can now be set to sorter! Just make sure to have it be a key based on what you - want it to display as. IE: `array('Main'=>'sidebars')` -* Added: Prevent Redux from firing on AJAX heartbeat, but added hook for it 'redux/ajax/heartbeat'. -* Added: Tick mark if section has sub sections. Hidden when subsections expanded. -* Added: Check to make sure a field isn't empty after the filter. If it is empty, skip over it. -* Added: Subsections now show icon if they have it. Show text only (without indent) if they do not. -* Added: Set a section or field argument of `'panel' => false` to skip over that field or panel and hide it. - It will still be registered with defaults saved, but not display. This can be useful for things - like the customizer. -* Added: SUBSECTIONS! Just add `'subsection' => true` to any section that isn't a divide/callback and isn't - the first section in your panel. ;) - -= 3.2.1 = -* Fixed: Small bug in image_select javascript. -* Added: Import hook, just because we can. :) -* Fixed: Customizer preview now TRULY outputs CSS even if output_tag is set to false; -* Fixed: Reset section, etc. Discovered an odd WordPress thing. -* Fixed: Image_select size override. -* Fixed: Customizer save not firing the compiler hook. -* Fixed: Customizer not outputting CSS if output_tag is set to false. -* Fixed: Small empty variable check. Undefined index in the defaults generating function. -* Fixed: WP 3.9 update made editor field button look ugly. -* Fixed: Save hook not firing when save_default set to false. -* Fixed: Reset section anomalies. Maybe. -* Fixed: Array of values in required not recognized. -* Fixed: Updated hint defaults to prevent index warning. -* Fixed: Removed leftover debug code. -* Added: New readonly argument for text field. -* Fixed: Reset/Reset section actions hooks now fire properly. -* Fixed: When developer uses section field but does not specify an indent argument. -* Fixed: Dynamic URL for slides -* Fixed: Accidently removed reset action on section reset. Restored. -* Fixed: Section defaults bug for certain field types. -* Fixed: Dynamic URL if site URL changed now updates media properly if attachement exists. -* Fixed: Customizer now correctly does live preview. -* Fixed: Special enqueue case fix. -* Added: A few more hooks for defaults and options. -* Fixed: Small undefined index error. -* Added: Section key generation via title. -* Modified: File intending. -* Fixed: Custom menus not displaying options panel. -* Fixed: Single checkbox option not retaining checked value. -* Fixed: Border field returning bad CSS in CSS compiler. -* Fixed: Import/Export fix. Thanks, @CGlingener! - -= 3.2.0 = -* Added: Save warning now is sticky to the top and responsive. -* Fixed: Mobile fixes for Redux. Looks great on small screens how. -* Fixed: Slight CSS fixes. -* Fixed: Compiler fixes and added notices. -* Added: Import/Export more reasonable text. -* Added: `force_output` on the field level to bypass the required check that removes the output if the field is hidden. Thanks @rffaguiar. -* Fixed: Fully compatible with WordPress 3.9. Now it just works. ;) -* Fixed: Info and divide field now work with required. -* Added: Fallback. Now if the media, slides, or background URL doesn't match the site URL, but the attachment ID is present, the data is updated. -* Fixed: Last tab not properly set. Slow rendering. -* Modified: Replaced transients with cookies. Less DB queries. -* Fixed: Undefined variable issues for new required methods. -* Fixed: Default_show display error with a non-array being steralized. -* Added: Multiple required parent value checking! Booya! -* Fixed: Sections now fold with required. -* Fixed: select2 not rendering properly when dev_mode = false, because of ace_editor fix. -* Fixed: Removed mistakenly compiled test code from redux.js. -* Fixed: ace_editor not rendering properly in certain instances. -* Modified: Small change to import_export field in checking for existing instance of itself. -* Fixed: import_export not rendering when the menutype argument was set to menu -* Fixed: Ace_editor not enqueued unless used. MEMORY HOG. -* Fixed: Color_Gradient transparency to was being auto-selected if from way transparent. -* Fixed: Enqueue select with slider for local dev. -* Modified: removed add_submenu_page when creating a submenu for us in the WP admin area. WP approved API is used in it's place to being Redux up to wp.org theme check standards. -* Fixed: Massive speed issue with button_set. Resolved. -* Fixed: Issue where default values throws an error if ID is not set. -* Fixed: Continuing effort to ensure proper loading of config from child themes. -* Fixed: Import/Export array search bug if section['fields'] is not defined. -* Fixed: Inconsistencies in import/export across different versions of PHP. -* Fixed: Redux checks for child or parent theme exclusively before loading. - -= 3.1.9 = -* Fixed: Typography custom preview text/size not outputting. -* Fixed: No font selected in typography would default to 'inherit'. -* Fixed: Hint feature kicking back a notice if no title was specified. -* Fixed: Sortable field, when used a checkboxes, were all checked by default, even when set not to be. -* Fixed: button_set field not setting properly in multi mode. -* Fixed: Javascript console object not printing options object. -* Fixed: Load errors from child themes no longer occur. -* Fixed: Compiler output for slider field. -* Fixed: update_check produced a fatal error on a local install with no internet connection. -* Fixed: Compiler hook failing on slider. -* Fixed: Error on update_check when the response code was something other than 200. -* Fixed: image_select images not resizing properly in FF and IE. -* Fixed: Layout for the typography field, so everything isn't smushed together. The new layout is as follows: -* Fixed: link_color field showing notice on default, if user enters no defaults. -* Fixed: Fixed tab notice in framework.php if no tab parameter is set in URL. -* Fixed: Hide demo hook wasn't hiding demo links. -* Added: Admin notice for new builds of Redux on Github as they become available. This feature is available on in dev_mode, and may be turned off by setting the `update_notice` argument to false. See the Arguments page of the wiki for more details. -* Added: text-transform option for the typography field. -* Added: Newsletter sign-up popup at first load of the Redux options panel. -* Added: Added PHP 5.2 support for import/export. -* Added: Action hooks for options reset and options reset section. -* Added: Theme responsive for date picker. -* Added: New slider. Better looking UI, double handles and support for floating point values. See the wiki for more info. -* Added: Typography improvements. -* Added: Hints! More info: https://github.com/ReduxFramework/ReduxFramework/wiki/Using-Hints-in-Fields -* Added: Complete Wordpress admin color styles. Blessed LESS/SCSS mixins. ;) -* Added: Font family not required for the typography module any longer. -* Added: Support for using the divide field in folding. -* Added: Error trapping in typography.js for those still attempting to use typography with no font-family. -* Added: Full asynchronous font loading. -* Added: email_not_empty validation field. -* Modified: Typography word and letter spacing now accept negative values. -* Modified: Typography preview shows spaces between upper and lower case groupings. -* Modified: Google font CSS moved to header so pages will pass HTML5 validation. -* Modified: Removed Google font CSS line from header (because it's in the footer via wp_enqueue_style. -* Modified: RGBA Field stability. Thank you, @SilverKenn. -* Modified: Separated Import/Export from the core. It can now be used as a field. - [family-font] [backup-font] - [style] [script] [align] [transform] - [size] [height] [word space] [letter space] - [color] -* Reverted: email validation field only checks for valid email. not_empty check moved to new validation field. - -= 3.1.8 = -* Fixed: Improper enqueue in tracking class. -* Fixed: Few classes missed for various fields. -* Fixed: Spacing field kicking back notices and warnings when 'output' wasn't set. -* Modified: Added file_exists check to all include lines in framework.php -* Fixed: Background field now works with dynamic preview as it should. -* Fixed: Extension fields now enqueueing properly. -* Added: Text-align to typography field. -* Fixed: Servers returning forwards slashes in TEMPLATEPATH, while Redux is installed embedded would not show options menu. -* Fixed: On and Off for switch field not displaying language translation. -* Fixed: email validation allowing a blank field. -* Fixed: Now allow for empty values as valid keys. -* Added: Dismiss option to admin notices (internal function) - -= 3.1.7 = -* Fixed: Servers returning forwards slashes in TEMPLATEPATH, while Redux is installed embedded would not show options menu. -* Fixed: On and Off for switch field not displaying language translation. -* Fixed: email validation allowing a blank field. -* Added: Dismiss option to admin notices (internal function) -* Fixed: On and Off for switch field not displaying language translation. -* Fixed: email validation allowing a blank field. -* Added: Dismiss option to admin notices (internal function) - -= 3.1.6 = -* Fixed: CSS spacing issue -* Fixed: Customizer now works and doesn't break other customizer fields outside of Redux. -* Fixed: Several minor bug fixes -* Added: Metabox support via extension http://reduxframework.com/extensions/ -* Added: Admin-bar menu -* Fixed: Section field now folds. -* Fixed: wp_content_dir path now handles double forward slashes. -* Fixed: Typography field missing italics in Google fonts. -* Fixed: Default color in border field not saving properly. -* Fixed: hex2rgba in class.redux_helpers.php changed to static. -* Fixed: 'sortable' field type not saving options as default. -* Fixed: Specified default color not set when clicking the color box default button. -* Fixed: Sorter field options are now saved as default in database. -* Fixed: Issues with checkboxes displaying default values instead of labels. -* Fixed: Outstanding render issues with spacing field. -* Fixed: Plugins using Redux from load failure. -* Fixed: 'not_empty' field validation. -* Fixed: Media field. -* Added: 'read-only' option for media text field. -* Added: 'mode' option to image_select, so CSS output element may be specified. -* Added: Admin Bar menu for option panel. -* Modified: media field 'read-only' to 'readonly' to vonform to HTML standards. -* Modified: Removed raw_align field and added align option to raw field. See wiki for more info. -* Removed: EDD extension. It never belonged in Core and will be re-released as a downloadable extension shortly -* Removed: Group field, temporarily. -* Removed: wp_get_current_user check. See https://github.com/ReduxFramework/ReduxFramework/wiki/How-to-fix-%22Fatal-error%3A-Call-to-undefined-function-wp_get_current_user%28%29-%22 - -= 3.1.5 = -* Typography font arrays may not contain comma spaces. -* Merge in pull request - 542, code cleanup and better readability -* Change how HTML is output to support metaboxes -* CSS only on pages that matter, better checks. -* font-backup in typography now appends to font-family in output and compiler. -* More fixes for Google font css outputting. -* Addded output and compiler to field_image_select. Images will be output as 'background-image'. -* Fixed output in field_background. -* Prevent standard fonts from outputting to Google fonts CSS call. -* class_exists in field_section checking for incorrect classname. -* sample_config fix. -* Compiler not outputting CSS without output set to comthing other than false. -* Google fonts not rendering on frontend. -* Rewrote sample_config as a class - -= 3.1.4 = -* Fixed error in redux-framework.php. -* Added select_image field. - -= 3.1.3 = -* Fixed a few undefined variables -* Removed old code from the repo. -* Fix for validation. -* Remove the compiler hook by default. -* Fix to sortable field. -* Added an extra check for link color. Removes user error. -* Localization updates. -* Error in slides. -* Fixed the info box bug with spacing and padding. -* Fixed the first item in each section having WAY too much padding. ;) -* Fixed section reset issue where values weren't being saved to the db properly. - -= 3.1.2 = -* Feature - Sortable select boxes! -* Feature - Reset a section only or the whole panel! -* New Field - RGBA Color Field! -* Improvement - Use of REM throughout. -* Fixed Typography - Fix output option and various small bugs. -* Fixed Border - Fix output option and various small bugs. -* Fixed Dimensions - Fix output option and various small bugs. -* Fixed Image_select - Various small bugs. -* Fixed Slides - Various small bugs. -* Fixed Sortable - Using native jQuery UI library same as within WordPress. -* Fixed Slider and Spinner Input Field - Values now move to the closest valid value in regards to the step, automatically. -* Fixed Ace Editor -* FEATURE - All CSS/JS files are compiled into a single file now! Speed improvements for the backend. -* Fix in how WordPress data is received, improved some output. -* Fix for various fields not triggering fold/compiler/save. -* Fixed elusive icons to use the new version and classes. -* Fixed media thumb to only be the thumbnail version. -* Fixed admin https error with WordPress core not renaming URL. -* Placeholders throughout the framework are now properly there. -* Feature - Setting to not save defaults to database on load. -* Fixed - Computability issue with GT3 builder. -* Fixed localization issue with default values. -* Language - Added Russian -* Feature - Media now can have any content type passed in to limit content types. -* Allow negative values in typography and other fields. -* WordPress 3.8 computability. -* CSS validation issue. -* Feature - User contributed text direction feature. -* EDD Extension now fully function for plugins or themes. -* Removed get_theme_data() fallbacks, we're well pass WordPress 3.4 now. ;) -* A ton of other small updates and improvements. - - -= 3.1.0 = -* Fix Issue 224 - Image Select width was breaking the panel. -* Fix Issue 181 - Broken panel in firefox -* Fix Issue 225 - 0px typography bug. Thanks @partnuz. -* Fix Issue 228 - Resolved a duplicated enqueue on color_link field. Thanks @vertigo7x. -* Fix Issue 231 - Field spacing bug fixes. -* Fix Issue 232 & 233 - Dimensions: bug fix with units and multiple units. Thanks @kpodemski -* Fix Issue 234 - Pass options as a ref so validating actions can modify/sanitize them. Thanks @ZeroBeeOne -* Fix Issue 222 - Tab cookie function wasn't working. -* Feature - Pass params to Select2. Thanks @andreilupu -* Fix Issue 238 - Fix for conditional output. Thanks @partnuz. -* Fix Issue 211 - Google Web font wasn't loading at first init of theme. -* Fix Issue 210 - Elusive Icons update. Changed classes to force use of full elusive name. -* Fix Issue 247 - Media thumbnails were not showing. Also fixed media to keep the largest file, but display the small version in the panel as a thumb. Thanks @kwayyinfotech. -* Fix Issue 144 - JS error when no item found in slider. -* Fix Issue 246 - Typography output errors. -* Feature & Issue 259 - Multi-Text now support validation! -* Fix Issue 248/261 - Links color issue. Also fixed color validation. -* Feature & Issue 262 - Now registered sidebars can be used as a data type. -* Fix Issue 194/276 - Custom taxonomy terms now passing properly. Thanks @kprovance. -* Feature & Issue 273 - Argument save_defaults: Disable the auto-save of the default options to the database if not set. -* Feature - Docs now being moved to the wiki for community participation. -* Issue 283 - Date placeholder. Thanks @kprovance. -* Issue 285 - HTTPS errors on admin. Known WordPress bug. Resolved. -* Fix Issue 288 - Float values now possible for border, dimensions, and spacing. -* Feature - Media field can now accept non-image files with a argument being set. -* Fix Issue 252 - Post Type data wasn't working properly. Thanks @Abu-Taymiyyah. -* Fix Issue 213 - Radio and Button Set wasn't folding. - -= 3.0.9 = -* Feature - Added possibility to set default icon class for all sections and tabs. -* Feature - Make is to the WP dir can be moved elsewhere and Redux still function. -* Added Spanish Language. Thanks @vertigo7x. -* Fix Issue 5 - Small RGBA validation fix. -* Fix Issue 176 - Fold by Image Select. Thanks @andreilupu. -* Fix Issue 194 - Custom taxonomy terms in select field. -* Fix Issue 195 - Border defaults not working. -* Fix Issue 197 - Hidden elements were showing up on a small screen. Thanks @ThinkUpThemes. -* Fix issue 200 - Compiler not working with media field. -* Fix Issue 201 - Spacing field not using default values. -* Fix Issue 202 - Dimensions field not using units. -* Fix Issue 208 - Checkbox + Required issue. -* Fix Issue 211 - Google Font default not working on page load. -* Fix Issue 214 - Validation notice not working for fields. -* Fix Issue 181/224 - Firefox 24 image resize errors. -* Fix Issue 223 - Slides were losing the url input field for the image link. -* Fix - Various issues in the password field. -* Fixed various spelling issues and typos in sample-config file. -* Initialize vars before extract() - to shut down undefined vars wargnings. -* Various other fixes. - -= 3.0.8 = -* Version push to ensure all bugs fixes were deployed to users. Various. - -= 3.0.7 = -* Feature - Completely redone spacing field. Choose to apply to sides or all at once with CSS output! -* Feature - Completely redone border field. Choose to apply to sides or all at once with CSS output! -* Feature - Added opt-in anonymous tracking, allowing us to further analyze usage. -* Feature - Enable weekly updates of the Google Webfonts cache is desired. Also remove the Google Webfont files from shipping with Redux. Will re-download at first panel run to ensure users always have the most recent copy. -* Language translation of german updated alone with ReduxFramework pot file. -* Fix Issue 146 - Spacing field not storing data. -* Fix - Firefox field description rendering bug. -* Fix - Small issue where themes without tags were getting errors from the sample data. - -= 3.0.6 = -* Hide customizer fields by default while still under development. -* Fix Issue 123 - Language translations to actually function properly embedded as well as in the plugin. -* Fix Issue 151 - Media field uses thumbnail not full image for preview. Also now storing the thumbnail URL. Uses the smallest available size as the thumb regardless of the name. -* Fix Issue 147 - Option to pass params to select2. Contributed by @andreilupu. Thanks! -* Added trim function to ace editor value to prevent whitespace before and after value keep being added -* htmlspecialchars() value in pre editor for ace. to prevent html tags being hidden in editor and rendered in dom -* Feature: Added optional 'add_text' argument for multi_text field so users can define button text. -* Added consistent remove button on multi text, and used sanitize function for section id -* Feature: Added roles as data for field data -* Feature: Adding data layout options for multi checkbox and radio, we now have quarter, third, half, and full column layouts for these fields. -* Feature: Eliminate REDUX_DIR and REDUX_URL constants and instead created static ReduxFramework::$_url and ReduxFramework::$_dir for cleaner code. -Feature: Code at bottom of sample-config.php to hide plugin activation text about a demo plugin as well as code to demo how to hide the plugin demo_mode link. -* Started work on class definitions of each field and class. Preparing for the panel builder we are planning to make. - -= 3.0.5 = -* Fixed how Redux is initialised so it works in any and all files without hooking into the init function. -* Issue #151: Added thumbnails to media and displayed those instead of full image. -* Issue #144: Slides had error if last slide was deleted. -* Color field was outputting hex in the wrong location. -* Added ACE Editor field, allowing for better inline editing. - -= 3.0.4 = -* Fixed an odd saving issue. -* Fixed link issues in the framework -* Issue #135: jQuery UI wasn't being properly queued -* Issue #140: Admin notice glitch. See http://reduxframework.com/2013/10/wordpress-notifications-custom-options-panels/ -* Use hooks instead of custom variable for custom admin CSS -* Added "raw" field that allows PHP or a hook to embed anything in the panel. -* Submenus in Admin now change the tabs without reloading the page. -* Small fix for multi-text. -* Added IT_it and RO_ro languages. -* Updated readme file for languages. - -= 3.0.3 = -* Fixed Issue #129: Spacing field giving an undefined. -* Fixed Issue #131: Google Fonts stylesheet appending to body and also to the top of the header. Now properly placed both at the end of the head tag as to overload any theme stylesheets. -* Fixed issue #132 (See #134, thanks @andreilupu): Could not have multiple WordPress Editors (wp_editor) as the same ID was shared. Also fixed various styles to match WordPress for this field. -* Fixed Issue #133: Issue when custom admin stylesheet was used, a JS error resulted. - -= 3.0.2 = -* Improvements to slides, various field fixes and improvements. Also fixed a few user submitted issues. - -= 3.0.1 = -* Backing out a bit of submitted code that caused the input field to not properly break. - -= 3.0.0 = -* Initial WordPress.org plugin release. - -= 3.0 = -Redux is now hosted on WordPress.org! Update in order to get proper, stable updates. - - -== Attribution == - -Redux is was originally based off the following frameworks: - -* [NHP](https://github.com/leemason/NHP-Theme-Options-Framework) -* [SMOF](https://github.com/syamilmj/Options-Framework "Slightly Modified Options Framework") - -It has now a completely different code base. If you like what you see, realize this is a labor of love. Please [donate to the Redux Framework](https://www.paypal.com/cgi-bin/webscr?cmd=_s-xclick&hosted_button_id=N5AD7TSH8YA5U) if you are able. diff --git a/library/admin/ReduxCore/assets/css/color-picker/color-picker.css b/library/admin/ReduxCore/assets/css/color-picker/color-picker.css deleted file mode 100644 index adf0cc46..00000000 --- a/library/admin/ReduxCore/assets/css/color-picker/color-picker.css +++ /dev/null @@ -1 +0,0 @@ -.redux-main input.redux-color{float:left;width:70px;margin-left:5px}.redux-main input.color-transparency{margin-left:10px;margin-right:3px}.redux-main input.wp-color-picker{width:80px !important}.redux-main .section-color .controls{width:345px}.redux-main .section-color .explain{width:225px}.redux-main .iris-picker .iris-strip .ui-slider-handle{position:absolute;background:none !important;right:-3px;left:-3px;border:4px solid #aaa !important;border-width:4px 3px;width:auto;border-radius:4px;box-shadow:0 1px 2px rgba(0,0,0,0.2);opacity:.9;z-index:5;cursor:ns-resize}.redux-main .iris-picker .iris-slider-offset{position:absolute;top:2px;left:0;right:0;bottom:4px;width:28px;background:none !important;border:0 !important;height:auto}.redux-main .wp-picker-container input{margin-bottom:inherit;margin-top:inherit;padding:3px 5px}.redux-main .wp-picker-container .wp-color-result{outline:0;margin:0}.redux-main .wp-picker-container .wp-picker-default{padding:0 10px 1px}.redux-main .redux-color-gradient{line-height:24px}.redux-main .color-transparency-check{line-height:1;margin-top:0px !important}.redux-main .wp-picker-clear{margin-top:0 !important}.wp-customizer .redux-main input.wp-picker-default,.wp-customizer .redux-main .redux-typography-container input.wp-picker-default,.wp-customizer .redux-main .redux-typography-container .redux-typography-color{padding:0px 4px !important}.wp-customizer .redux-main input.wp-color-picker{width:65px !important;margin-left:5px !important} diff --git a/library/admin/ReduxCore/assets/css/color-picker/color-picker.scss b/library/admin/ReduxCore/assets/css/color-picker/color-picker.scss deleted file mode 100644 index 8c8159c5..00000000 --- a/library/admin/ReduxCore/assets/css/color-picker/color-picker.scss +++ /dev/null @@ -1,97 +0,0 @@ -.redux-main { - input{ - &.redux-color { - float: left; - width: 70px; - margin-left: 5px; - } - - &.color-transparency { - margin-left: 10px; - margin-right: 3px; - } - - &.wp-color-picker { - width: 80px !important; - } - } - - .section-color { - .controls { - width: 345px; - } - - .explain { - width: 225px; - } - } - - .iris-picker { - .iris-strip .ui-slider-handle { - position: absolute; - background: none !important; - right: -3px; - left: -3px; - border: 4px solid #aaa !important; - border-width: 4px 3px; - width: auto; - border-radius: 4px; - box-shadow: 0 1px 2px rgba(0, 0, 0, .2); - opacity: .9; - z-index: 5; - cursor: ns-resize; - } - - .iris-slider-offset { - position: absolute; - top: 2px; - left: 0; - right: 0; - bottom: 4px; - width: 28px; - background: none !important; - border: 0 !important; - height: auto; - } - } - - .wp-picker-container { - input { - margin-bottom: inherit; - margin-top: inherit; - padding: 3px 5px; - } - - .wp-color-result { - outline: 0; - margin: 0; - } - - .wp-picker-default { - padding: 0 10px 1px; - } - } - - .redux-color-gradient { - line-height: 24px; - } - - .color-transparency-check { - line-height: 1; - margin-top: 0px !important; - } - - .wp-picker-clear { - margin-top: 0 !important; - } -} - -.wp-customizer { - .redux-main input.wp-picker-default, .redux-main .redux-typography-container input.wp-picker-default, .redux-main .redux-typography-container .redux-typography-color { - padding: 0px 4px !important; - } - .redux-main input.wp-color-picker { - width: 65px !important; - margin-left: 5px !important; - } -} \ No newline at end of file diff --git a/library/admin/ReduxCore/assets/css/import_export/import_export.css b/library/admin/ReduxCore/assets/css/import_export/import_export.css deleted file mode 100644 index 70f310d3..00000000 --- a/library/admin/ReduxCore/assets/css/import_export/import_export.css +++ /dev/null @@ -1 +0,0 @@ -#redux-import-link-wrapper,#redux-import-code-wrapper{display:none}#redux-export-code,#redux-export-link-value{display:none}#redux-import-action span{color:#B94A48} diff --git a/library/admin/ReduxCore/assets/css/media/media.css b/library/admin/ReduxCore/assets/css/media/media.css deleted file mode 100644 index 737309c1..00000000 --- a/library/admin/ReduxCore/assets/css/media/media.css +++ /dev/null @@ -1 +0,0 @@ -.redux-main .button.remove-image,.redux-main .removeCSS{margin-left:10px;color:#ef521d}.redux-main .button.remove-image:hover,.redux-main .removeCSS:hover{color:red}.redux-main .upload_button_div{margin-bottom:5px}.redux-main .upload-error{float:left;color:#666;font-size:10px;font-weight:bold;text-decoration:none;text-shadow:1px 1px 0 #FFFFFF;margin:0 10px 0 0;padding:3px 10px;background:#FFDFEC;-webkit-border-radius:4px;-moz-border-radius:4px;border-radius:4px}.redux-main .reset-button{font-family:Arial, Verdana, sans-serif;float:left;margin:0;color:#ef521d;border-color:#bbb}.redux-main .redux-option-image{max-height:340px;max-width:340px;padding:5px;margin-bottom:0;margin-top:10px;margin-right:15px;border:1px solid #e3e3e3;background:#f7f7f7;-moz-border-radius:3px;-khtml-border-radius:3px;-webkit-border-radius:3px;border-radius:3px}.redux-main .redux-main .upload{width:80% !important}.redux-main .button{margin-top:2px} diff --git a/library/admin/ReduxCore/assets/css/media/media.scss b/library/admin/ReduxCore/assets/css/media/media.scss deleted file mode 100644 index 86086aed..00000000 --- a/library/admin/ReduxCore/assets/css/media/media.scss +++ /dev/null @@ -1,61 +0,0 @@ -.redux-main { - .button.remove-image, - .removeCSS { - margin-left: 10px; - color: #ef521d; - - &:hover { - color: red; - } - } - - .upload_button_div { - margin-bottom: 5px; - } - - .upload-error { - float: left; - color: #666; - font-size: 10px; - font-weight: bold; - text-decoration: none; - text-shadow: 1px 1px 0 #FFFFFF; - margin: 0 10px 0 0; - padding: 3px 10px; - background: #FFDFEC; - -webkit-border-radius: 4px; - -moz-border-radius: 4px; - border-radius: 4px; - } - - .reset-button { - font-family: Arial, Verdana, sans-serif; - float: left; - margin: 0; - color: #ef521d; - border-color: #bbb; - } - - .redux-option-image { - max-height: 340px; - max-width: 340px; - padding: 5px; - margin-bottom: 0; - margin-top: 10px; - margin-right: 15px; - border: 1px solid #e3e3e3; - background: #f7f7f7; - -moz-border-radius: 3px; - -khtml-border-radius: 3px; - -webkit-border-radius: 3px; - border-radius: 3px; - } - - .redux-main .upload { - width: 80% !important; - } - - .button { - margin-top: 2px; - } -} \ No newline at end of file diff --git a/library/admin/ReduxCore/assets/css/redux-admin.css b/library/admin/ReduxCore/assets/css/redux-admin.css deleted file mode 100644 index f35a13ca..00000000 --- a/library/admin/ReduxCore/assets/css/redux-admin.css +++ /dev/null @@ -1 +0,0 @@ -.spinner{visibility:hidden;display:block}.spinner.is-active{visibility:visible}.redux-main .description{margin-top:7px}.form-table>tbody>tr>th{width:30%}.redux-container{background-color:#f5f5f5;background-repeat:repeat-x;background-image:-moz-linear-gradient(top, #f2f2f2 0%, #f5f5f5 100%);background-image:-webkit-gradient(linear, left top, left bottom, color-stop(0%, #f2f2f2), color-stop(100%, #f5f5f5));background-image:-webkit-linear-gradient(top, #f2f2f2 0%, #f5f5f5 100%);background-image:-ms-linear-gradient(top, #f2f2f2 0%, #f5f5f5 100%);background-image:-o-linear-gradient(top, #f2f2f2 0%, #f5f5f5 100%);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#f5f5f5', endColorstr='#eeeeee', GradientType=0);background-image:-linear-gradient(top, #f2f2f2 0%, #f5f5f5 100%);border:1px solid #dedede;-webkit-box-shadow:0 1px 1px rgba(0,0,0,0.04);box-shadow:0 1px 1px rgba(0,0,0,0.04);-moz-box-shadow:0 1px 5px rgba(0,0,0,0.4);margin-top:5px;overflow:hidden}.redux-container a:focus{box-shadow:none}.redux-container #redux-header,.redux-container #redux-footer{text-align:right;padding:6px 10px}.redux-container #redux-header{background:#f1f1f1;border-bottom:3px solid blue}.redux-container #redux-header .display_header{float:left;margin:20px 10px}.redux-container #redux-header .display_header h2{display:inline-block;font-style:normal;padding-right:5px}.redux-container #redux-header .display_header .redux-dev-mode-notice-container{position:absolute;top:67px;left:20px;bottom:auto;width:auto}.redux-container #redux-header .display_header span{color:#888}.redux-container #redux-header .display_header span.redux-dev-mode-notice{background-color:#f0ad4e;display:inline;padding:.2em .5em .2em;font-weight:700;line-height:1;color:#fff !important;text-align:center;white-space:nowrap;vertical-align:baseline;border-radius:.25em}.redux-container #redux-header .icon32{float:right;margin:16px 16px 0}.redux-container #redux-footer{border-top:1px solid #E7E7E7;z-index:999}.redux-container #redux-footer #redux-share{float:left;line-height:28px;font-size:15px}.redux-container #redux-footer #redux-share a{text-decoration:none;margin-right:10px}.redux-container #redux-footer #redux-share a img{margin-bottom:-3px}.redux-container .notice-green{margin:0;border-bottom:1px solid #E7E7E7;background-color:#DFF0D8;color:#468847;padding:8px 35px 8px 14px;text-shadow:0 1px 0 rgba(255,255,255,0.5)}.redux-container .notice-blue{margin:0;border-bottom:1px solid #BCE8F1;background-color:#D9EDF7;color:#3A87AD;padding:8px 35px 8px 14px;text-shadow:0 1px 0 rgba(255,255,255,0.5)}.redux-container .notice-yellow{margin:0;border-bottom:1px solid #E7E7E7;background-color:#FCF8E3;color:#C09853;padding:8px 35px 8px 14px;text-shadow:0 1px 0 rgba(255,255,255,0.5)}.redux-container .notice-red,.redux-container .redux-field-errors{margin:0;border-bottom:1px solid #E7E7E7;background-color:#F2DEDE;color:#B94A48;padding:8px 35px 8px 14px;text-shadow:0 1px 0 rgba(255,255,255,0.5)}.redux-container .redux-field-error input,.redux-container .redux-field-error textarea,.redux-container .redux-field-error checkbox{background-color:#FFF6F6;color:#A00}.redux-container .redux-field-warning input,.redux-container .redux-field-warning textarea,.redux-container .redux-field-warning checkbox{background-color:#fcf8e3;color:#444}.redux-container .redux-field-errors,.redux-container .redux-field-warnings,.redux-container .redux-save-warn{display:none}.redux-container .sticky-save-warn{min-height:76px}.redux-container .sticky-save-warn .redux-save-warn{position:fixed;top:32px;right:21px;left:183px;opacity:1;z-index:9999}.redux-container #info_bar{background:#f3f3f3;border-bottom:1px solid #dedede;padding:6px 10px 6px 6px;text-align:right;-moz-box-shadow:inset 0 1px 0 #fcfcfc;-webkit-box-shadow:inset 0 1px 0 #fcfcfc;box-shadow:inset 0 1px 0 #fcfcfc}.redux-container .redux-group-tab{display:none;margin-bottom:15px}.redux-container .redux-group-tab .redux-theme-data{padding:20px 0;border-top:1px solid #E7E7E7}.redux-container .redux-group-tab .redux-theme-data.theme-description{padding:10px 0;border-width:0}.redux-container .redux-group-tab .redux-theme-data.theme-uri,.redux-container .redux-group-tab .redux-theme-data.theme-author,.redux-container .redux-group-tab .redux-theme-data.theme-version{padding:0;border-width:0}.redux-container .redux-group-tab h3{margin-top:0;line-height:2em;border-bottom:1px solid #E7E7E7}.redux-container .redux-group-tab .redux-section-desc{margin-bottom:15px;color:#666}.redux-container .redux-action_bar{float:right}.redux-container .redux-action_bar .spinner{float:left;margin-top:4px}.redux-container .redux-ajax-loading{display:none;background:red url(data:image/gif;base64,R0lGODlhEAAQAPUAAIiIiIqKio2NjZSUlJqamp6enqKioqSkpK+vr7i4uL+/v8PDw8XFxcnJyc/Pz9HR0dTU1NjY2Nzc3OLi4ubm5unp6ezs7PPz88vLy83NzdDQ0NXV1d3d3eHh4bu7u8zMzOvr6+3t7ZiYmNbW1sDAwMTExNra2s7OztPT09vb2+Xl5QAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAACH/C05FVFNDQVBFMi4wAwEAAAAh/i1NYWRlIGJ5IEtyYXNpbWlyYSBOZWpjaGV2YSAod3d3LmxvYWRpbmZvLm5ldCkAIfkEAAoA/wAsAAAAABAAEAAABXDgJY6XZZEoOTnOlI5WdUFNA5UnSR3FJNUSieFAIUUEgcdl4noEBBGSZaHIiSqKhTX2GhVFiQGjuxgkSoYAoosAGE6RhKQrUURHlS+pItMVCHMjEgQ9JBJISg+JT3ciFg4NFkcCNw0OViiDgF0oTC8hACH5BAAKAP8ALAAAAAAQABAAAAVx4CWOZGle1qJYp2hV1xYE29V1JXUYHWUcnQgGwyFFBAENiqUZ1kapFamTyeBcsNOLMkoMGC3GIIEyBBAtRMDAiiSKp04iQqpwc9kRpUCAizgEBVciEQNJFxpKGgECdFAYYBsCAjUMGS0XgAODmDacIyEAIfkEAAoA/wAsAAAAABAAEAAABnbAi3BILBovIMUidBSGQJdNIKBBMomUg6FDMRgoHcOBQowIqNaLJiCIEEMLxdWpnIfITRAHnxgwjiEfDR8UIQYBCEcgDYwdUR6ORxEfG3MgeFiFRB0FBBxEHAQFkUJmaBofamxuRB9/GwICGxeMTRehnrabpERBACH5BAAKAP8ALAAAAAAQABAAAAZ9wItwSCwaL5aFwnIUWiqXUSAwulSYRMrB0KEYDJSO4UAhRgQBDZLpCAgixOSSWFEssEho81IWJgYMTQwDCUgGAQhNCAEGTCMJHU0dCXBDFX1DFhwdeHwFIhxmGBihQxEDaRcOGhYao1WZGIFnAiMUDg6YRR0ioE57Fx2RRkEAIfkEAAoA/wAsAAAAABAAEAAABXLgJY5kaV7WolinaLGQEEBXxZLUUUyUYVATw4FCisg0NZYmIIiQUosKqaJY3FDS1oUoSgwYrcUggTIAEC1EwMCKJCatSYI2qnBx2dGkQOCQOAQFdxdGARoVGhCITE4kGBgWEI8QFgwYWhGTWiMWERFXIyEAIfkEAAoA/wAsAAAAABAAEAAABn/Ai3BILBovloXCchRaKpdRIDC6VJhEysHQoRgMlI7hQCFGBAENkukICCLE5JJYUSywSGjzUhYmBgxNDAMJSAYBCE0IAAZMEQkdTRwKVUMcHHhCFXpDERgYcJYEBZFDI58aFhoOFxpuoUIUGhoUZwJVGA6ZaxccBAQce0QdpUVBACH5BAAKAP8ALAAAAAAQABAAAAZ8wItwSCwaLyEFKXQUhioXSCAAuVSYRMrB0KEYDJSO4UAhmgQBDZKpCQhMxFBJgRVWlFkOtElhUj4NH3VEJQMJFx0NintFCAEGISEQH3BHHR5VThVlRRSMQh0FBBxEHAQFnEJnaRcfHxdtb0WKIWcCVSUNTYgEo7tEHR1HQQAh+QQACgD/ACwAAAAAEAAQAAAGdcCLcEgsGi8hhSJ0FHY6l1EgMLqAmEROo5HqGAwqL5g42qKsoAsqIEgRVacTdAhSLLBI1bWpwiYGDE0MAwlIBgEITQgBBkwjCRxNHQlVdCpGekUqBQSRQxwEBZdDKQIBZ3FqbG5EDYEjpikhW3hFoJ1NRU9HQQA7) no-repeat;width:16px;height:16px;margin:3px 4px 0;float:right}.redux-container #redux-intro-text{background:#f3f3f3;border-bottom:1px solid #dedede;-moz-box-shadow:inset 0 1px 0 #fcfcfc;-webkit-box-shadow:inset 0 1px 0 #fcfcfc;box-shadow:inset 0 1px 0 #fcfcfc;padding:3px;padding:10px 10px}.redux-container #redux-intro-text p{margin:0;font-family:"Lucida Grande", Sans-serif;color:#888}.redux-container .expand_options{cursor:pointer;display:block;height:22px;width:21px;float:left;font-size:0;text-indent:-9999px;margin:1px 0 0 5px;border:1px solid #bbb;-webkit-border-radius:2px;-moz-border-radius:2px;border-radius:2px;background:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABkAAAAyCAIAAAAm4OfBAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAQhJREFUeNrslT0KhDAQhTeLR7ATT6IXSKGFYO0lciFrO1N4AU8TLNXKv0CaJbLJRAZxl1hYyJuXN+PoR/Z9fyFdBNNr27Zf8Oq6bhgGSGUYhpTSzyeBNi8hRFVVEK+6rrXaQFOs6yrvTdOYjcqyVEpTLqXI89yaSypBudq2xckF2TipOSvfmmhZFuAGnJV6Licvey5gj7fnwpwXvEfLfqnT0jQ1OBJCQLnUBvZ9b85VFAV076UU8g1ZckVRxBiDzD6OY62WzPOM9i+cpunvvcZxfCQfPWs9a91Ym2UZ5xyHtd/e8hXWng+/zlrD9jmz1tDj7bkw5wXv0Y210itJEs9az9oHsPYQYACveK0/IuB51AAAAABJRU5ErkJggg==) no-repeat -2px -26px}.redux-container .expand_options.expanded{background:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABkAAAAyCAIAAAAm4OfBAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAQhJREFUeNrslT0KhDAQhTeLR7ATT6IXSKGFYO0lciFrO1N4AU8TLNXKv0CaJbLJRAZxl1hYyJuXN+PoR/Z9fyFdBNNr27Zf8Oq6bhgGSGUYhpTSzyeBNi8hRFVVEK+6rrXaQFOs6yrvTdOYjcqyVEpTLqXI89yaSypBudq2xckF2TipOSvfmmhZFuAGnJV6Licvey5gj7fnwpwXvEfLfqnT0jQ1OBJCQLnUBvZ9b85VFAV076UU8g1ZckVRxBiDzD6OY62WzPOM9i+cpunvvcZxfCQfPWs9a91Ym2UZ5xyHtd/e8hXWng+/zlrD9jmz1tDj7bkw5wXv0Y210itJEs9az9oHsPYQYACveK0/IuB51AAAAABJRU5ErkJggg==) no-repeat -2px -1px}.redux-container .expand_options:hover{border-color:#888}.redux-container .sticky-footer-fixed{background:#f3f3f3;border-top:1px solid #dedede !important;-moz-box-shadow:inset 0 1px 0 #fcfcfc;-webkit-box-shadow:inset 0 1px 0 #fcfcfc;box-shadow:inset 0 1px 0 #fcfcfc}.redux-container .redux-sidebar,.redux-container .redux-main{min-height:300px}.no-js{border:1px solid #ffbaba;margin:0;border-bottom:1px solid #E7E7E7;background-color:#F2DEDE;color:#B94A48;padding:8px 35px 8px 14px;text-shadow:0 1px 0 rgba(255,255,255,0.5)}.redux-main{background:#FCFCFC;margin-left:201px;border-left:1px solid #D8D8D8;padding:10px 20px;-moz-box-shadow:inset 0 1px 0 #fff;-webkit-box-shadow:inset 0 1px 0 #FFF;box-shadow:inset 0 1px 0 #FFF;position:relative}.redux-main #redux_ajax_overlay{position:absolute;top:0;left:0;right:0;bottom:0;-moz-opacity:0.10;-khtml-opacity:0.10;opacity:0.10;filter:progid:DXImageTransform.Microsoft.Alpha(opacity=10);filter:alpha(opacity=10);background:#000;z-index:200;display:none}.redux-main .form-table.no-border{border-top:none}.redux-main .form-table tr{border-bottom:1px solid #E7E7E7}.redux-main .form-table tr:last-child{border-bottom:none !important}.redux-main .form-table tr th,.redux-main .form-table tr td{color:#333}.redux-main .form-table tr td table.mceLayout,.redux-main .form-table tr td table.mceLayout tr,.redux-main .form-table tr td table.mceLayout tr td{padding:0;border-width:0}.redux-main .form-table tr td .redux-th-warning{font-size:1em;color:#C09853;font-weight:normal;display:block;margin-top:10px}.redux-main .form-table tr td .redux-field-warning{border-color:#C09853;margin-top:10px}.redux-main .form-table tr td .redux-th-error{font-size:1em;color:#B94A48;font-weight:normal;display:block;margin-top:10px}.redux-main input.large-text{width:100%}.redux-main .hide{display:none}.redux-main .redux-field-container{padding:20px 0}.redux-main .mini,.redux-main input[type=text].mini{width:60px;text-align:center}.redux-main input{line-height:19px}.redux-main img{max-width:100%;height:auto;width:auto !important}.redux-main .select2-default{width:auto !important}.redux-main .showDefaults{display:block;font-weight:normal;font-size:.8em;color:#888}.redux-main span.description{display:block;font-style:normal;font-weight:400}.redux-main #redux-system-info textarea{min-height:730px;width:100%}.redux-main .field-desc{clear:both;font-size:13px}.redux-main .data-full li{width:100%}.redux-main .data-half li{width:50%;float:left}.redux-main .data-third li{width:33.3%;float:left}.redux-main .data-quarter li{width:25%;float:left}.redux-main .ui-helper-hidden-accessible{top:inherit}.redux-main .form-table{clear:none;margin-top:0px !important}.redux-main .form-table tr:first-child th,.redux-main .form-table tr:first-child td{padding-top:0}.redux-main .input-append input{border-right:0;margin-bottom:0;border-top-right-radius:0;border-bottom-right-radius:0;margin-right:0;float:left;margin-top:0;display:block}.redux-main .input-append .add-on{border-top-right-radius:3px;border-bottom-right-radius:3px;margin-left:-2px;padding-top:4px !important;padding-bottom:2px !important}.redux-main .input-prepend input{border-left:0;margin-bottom:0;border-top-left-radius:0;border-bottom-left-radius:0;margin-left:0;padding-top:2px;padding-bottom:5px;float:left;margin-top:0;display:block}.redux-main .input-prepend .add-on{border-top-left-radius:3px;border-bottom-left-radius:3px;float:left}.redux-main .input-append{margin-right:10px;font-size:0;white-space:nowrap;float:left;display:inline-block;margin-bottom:6px}.redux-main .input-append .add-on,.redux-main .input-prepend .add-on{width:auto;display:inline-block;min-width:16px;padding:3px 4px;font-size:12px;font-weight:400;line-height:20px;text-align:center;text-shadow:0 1px 0 #ffffff;background-color:#eeeeee;border:1px solid #cccccc}.redux-main .input-prepend{font-size:0;white-space:nowrap;float:left;display:inline-block;margin-bottom:6px}.redux-sidebar{width:202px;float:left}.redux-sidebar .redux-group-menu{margin-top:0 !important}.redux-sidebar .redux-group-menu li{margin-top:0}.redux-sidebar .redux-group-menu li.active a,.redux-sidebar .redux-group-menu li.active a:hover,.redux-sidebar .redux-group-menu li.activeChild a,.redux-sidebar .redux-group-menu li.activeChild a:hover{background:#FCFCFC;color:#269ad6;width:184px;opacity:1}.redux-sidebar .redux-group-menu li.active a li a{background:#333;padding-left:5px}.redux-sidebar .redux-group-menu li.divide{padding:0;border-width:1px 0;border-style:solid;border-bottom-color:#E7E7E7;border-top-color:#F9F9F9}.redux-sidebar .redux-group-menu li a:first-child{border-top:none}.redux-sidebar .redux-group-menu li a{display:block;padding:10px 4px 10px 14px;background:#e0e0e0;background:transparent;border-width:1px 0;border-style:solid;border-bottom-color:#E7E7E7;border-top-color:#F9F9F9;opacity:0.7;color:#555;font-weight:bold;text-decoration:none;-webkit-transition:none;transition:none}.redux-sidebar .redux-group-menu li a.custom-tab{background:#f6f6f6}.redux-sidebar .redux-group-menu li a img{width:16px;height:16px;position:absolute;left:15px}.redux-sidebar .redux-group-menu li a:hover{background:#e5e5e5;color:#777;opacity:1}.redux-sidebar .redux-menu-warning,.redux-sidebar .redux-menu-error,.redux-sidebar .hasSubSections .extraIconSubsections{display:inline-block;float:right;padding:6px 7px 4px 7px;margin-left:4px;font-family:sans-serif;font-size:9px;font-weight:bold;line-height:9px;border-radius:10px;-moz-border-radius:10px;-webkit-border-radius:10px;border:0 solid transparent}.redux-sidebar .redux-menu-warning i,.redux-sidebar .redux-menu-error i,.redux-sidebar .hasSubSections .extraIconSubsections i{margin-left:-3px;margin-top:-3px}.redux-sidebar .redux-menu-error{background-color:#b94a48;color:#f2dede}.redux-sidebar .redux-menu-warning{background-color:#C09853;color:#FCF8E3}.redux-sidebar ul .subsection{display:none}.redux-sidebar .redux-group-tab-link-a{position:relative;outline:0}.redux-sidebar .redux-group-tab-link-a i{vertical-align:middle;font-size:1.35em;position:absolute}.redux-sidebar .redux-group-tab-link-a span{display:block}.redux-sidebar .redux-group-tab-link-a span.group_title{padding-left:30px}.redux-sidebar .redux-group-tab-link-li a.hasError span.group_title{padding-right:25px}.redux-sidebar #redux-header{text-align:center}.redux-sidebar #redux-header .display_header{float:none}.form-table th,.form-table td{margin:0;padding:0;width:auto}.redux_field_th{font-weight:bold;padding:20px 10px 20px 0px;display:block}.redux_field_th span:first-child{font-weight:normal;display:block;color:#666}.farb-popup-wrapper{position:relative;display:block}.farb-popup{position:absolute;left:40px;top:40px;background-color:white;border:1px solid #222;padding:5px;z-index:100}#ui-datepicker-div{display:none}.mp6 .icon-themes{display:none}.mp6 .redux-container #info_bar{padding:6px 10px 6px 6px}.mp6 .redux-container #info_bar a{margin-top:2px}.redux-timer{text-align:center;font-size:10px;color:#888}.wrap{margin-top:0}@media screen and (max-width: 600px){.redux-sidebar{width:44px}.redux-sidebar .extraIconSubsections{display:none !important}.redux-sidebar .redux-group-menu li a,.redux-sidebar .redux-group-menu li a:hover,.redux-sidebar .redux-group-menu li.active a,.redux-sidebar .redux-group-menu li.active a:hover,.redux-sidebar .redux-group-menu li.activeChild a,.redux-sidebar .redux-group-menu li.activeChild a:hover{width:auto}.redux-sidebar .redux-group-tab-link-a{position:relative}.redux-sidebar .redux-group-tab-link-a i{position:inherit}.redux-sidebar .redux-group-tab-link-a span{display:none;position:absolute;top:0;left:44px;padding:12px;width:200px;background:#eeeeee;border:1px solid #ccc;-webkit-box-shadow:2px 2px 8px rgba(0,0,0,0.2);-moz-box-shadow:2px 2px 8px rgba(0,0,0,0.2);box-shadow:2px 2px 8px rgba(0,0,0,0.2);border-width:1px 1px 1px 0px;z-index:3}.redux-sidebar .redux-group-tab-link-a:hover>span{display:block}.redux-main{margin-left:43px;width:auto;max-width:100%}table.form-table,.form-table>thead,.form-table>tbody,.form-table>tbody>tr>th,.form-table>tbody>tr>td,.form-table>tbody>tr{display:block;width:100% !important;padding:0px !important}.form-table>tbody>tr>th,.form-table>tbody>tr>td{padding:10px !important}.form-table>tbody>tr>th,.form-table>tbody>tr>td{padding:10px !important}}@media screen and (max-width: 782px){.form-table>tbody>tr>th{width:100%}.redux_field_th{padding-bottom:0}.mp6 .redux-container #info_bar{height:auto;padding-bottom:1px}.mp6 .redux-container #info_bar a{margin-top:5px}.redux-container-switch label{padding:5px 10px !important}.redux-container-button_set label{padding:12px 10px}.redux-container #redux-footer #redux-share{line-height:34px}}pre{overflow:hidden}#redux-header h2{color:#fff}.admin-color-fresh .button.ui-datepicker-current,.admin-color-fresh button.ui-datepicker-close,.wp-customizer .button.ui-datepicker-current,.wp-customizer button.ui-datepicker-close{background-color:#007db9 !important}.admin-color-fresh .ui-datepicker-buttonpane button.ui-datepicker-current,.wp-customizer .ui-datepicker-buttonpane button.ui-datepicker-current{background:#1e8cbe !important;color:white !important;border:1px solid #104b66 !important}.admin-color-fresh .ui-datepicker-header .ui-icon,.wp-customizer .ui-datepicker-header .ui-icon{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAQAAAADwCAMAAADYSUr5AAAA7VBMVEX8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vywC3+8AAAATnRSTlMAGBAyBAhQv4OZLiJUcEBmYBoSzQwgPBZCSEoeWiYwUiyFNIeBw2rJz8c4RBy9uXyrtaWNqa2zKP2fJO8KBgKPo2KVoa9s351GPm5+kWho0kj9AAAPhUlEQVR4nO1djWLbthEGyUiq5YSSLXtp7FpLOmfzkmxr126tmi2p03RJ1/Xe/3EGgARxPyAgRbIk2/hkSz4CJO4+HsE7AJSVysjI2AMUUOxahZ2iANhzBtZWr4BoIRSYAVN5u4QwDwQDRbcwfUi5KS3wFuDmFnQLa4Dtb//cqktwD5QEFFwfUs7PoCCA7y4bEJVFizcIob8KmhAplwwqVjt+9FBl3uINQniwEiryEyw9JHqGpQdEFNi+B4QQ7QOiHhysIPoAxUqxvdvvA9K42bsAv4S2fxfYOe57IJSRkZGRkZGxx7jxSHDHcRBXQMTyIjInBgHwBJ/bEx8PEANC+uhbpSSggCBAVODVabpI1S/k4WLZpTn6NpMhoX9Y40hxYERFpMcqUs4AloCtDQdID1YhnyXZ2hLjAYWiO9Dy1PDB7tPhIqLx+uMB8grZaR+Qxl2/C2RkZGRkZGRk7A7rBf7J0DR5/LUTjzUPIPSPGvQJiVJiB7kcQCiUOJrcFNtDZIf2xarQ3aGvLNxAVIFAabz90BFiBIlycTBhgWwOWCH0FLYHlPqwHaCvcIn2ZbosCevfPTRiFFcgvHukCjWwrc3GrGh1fsAof8EaUReKXkCB4/MzFNo97qLpFiKFYv/kNR5YQxQbQEofkZ2OuEOHqqT6gFTpru8CN7x/+jaZkZGRkZGRcV+x/rLUNcMMqUAscgnFocmpqkTzqymwVAPxfJ5PnIUUQOUKT04tEdWZyv3JCQSn96WS4pD97QfyW25A7NhSAbyhmVj0FEltA4vdiygBibXhoUYgykCUP7HwPTDeEqAIcHVMkZg7Zx4k0uFANs63hPQXCoRLAwdgGsr9Az7Qv7sgQGgg1aPl/BJLExBWgG4RFRLFImGmIquPC/klEGyCG0AuAXaJJC+B8FVe9NYQDEcXB8g6AQcjYJ1goJIggHWCrFR0S6kRHN5+4BzFi8NaoN35NRxUvL+JJdZr7PV4wK6fj8nIyMjIyNhr3OxdXAYq7FHZwB6bDSzSh4sF0utChqo0NAvaT1hLzXwFinmCzmeDucEQK18TTaQoFgP7bNC+RZ4OT4T6gQogDFYk+1QxQlj19QGSAWKiLYp8P0Ag1Gbz1ULfWHLg9iUnQNK5QQJcukm04blKLH2GgEJCY+HzXAZWCvHKco3Bp6MIaCjSXXRJyOxeqhnzEaF93MfFGW/O16ZvDL5TM4MJIjujz/cHypkQuuzRwWJ93BKdIt+wCRAPl9kpe2Ikkb2mFgGlxh/i40d3EHfdvoyMjIyMu43ylt/IAmGHnN5iIt7wKfbv01RAcJqFRl9lcjYQSnbQqKgC4fYOwSJt6N6trE0twZ9kN/PqNpTQeICvr4TLsDYC06U7BMjshS+v1/aT7IwQYD5LcgRQXMT2FrBfBLjZ6151jDElk9tPFfpUgk2yregusX25BJbwAFEfM+YI6vGAti4bTtizB+TjfQCrERyhKb2X8D6A9wX75P4t4neBYJeP6pdhg/gQl8MWvytzeSTjgOQBynQdh/iXKdxOrGJ/RkZGRsb9QmXihGr5+g8GGg9uTh+KoVZuNIzV+CwRucFBEyr1mVjx4irOxwM1BhirB6Q+2eNQi4eqR+aF6mELtoMzCR7V9RAFe/ZvQogNiyY8FPSUTFsLp8TeTmMui5mtw7bcaT0Yw2AA4wFRQIlkgq+1DQrNhkmoxS5Jq+u6bMAIGRECEANgXHTgWzwgBOhDH2l0oTQ4D8D5NMktBgNywAEMjo8rwATMZrPY7JGxBoJCkIBDQiAY09EGTUiBCWkUpISfGPR5AAwBfZiG2z7Ayc1yeKTxid39xBNwfHr4O0LA48ePFTvhYrF1r4tyAoz9n2MCqEuBtp/6GDR0oAYfG/R6wJExHYZHfhygsv7fEWCOj4bYmsP5A+pL4MkTfAnMlD4F+r3bobKvTyTA2P/w7PN+Agq2QW8piqMCpTBwenoKvX0AHGkGtP2YAPvTEWA7QUTAudn7/NxtOG46wWNmDtpBEkBzN7rBEvAFHp+YTB/q97qPAN4gHFqgBi8uLsC7qPCA6mg41G/+ErByPwEXDdoNxRhOx+M5jPEzQugS0ht+b1/Y3gEnYMAIAOIBE29/hIDucE8tmMsNOgK4B1RHFu4UCRlMHzv0xzcajcfdXWDs2h8TArBCkoDUJYDLmz6w7ip3BFS0ve5wTRwAn6keMA9I3QYbfSZ0DKbyt+7OXjGI1idPcfNyAyfAMlCrzaGqphYrxHocLHRJVycnfGUcbtT+jIyMjIw9x7Nn8fJSzG0TmFtO8rZT+XT3S3ub+tKJbbLd5diTVp50+zahyeHSslJ/YPrU0fuazrZO2CZ92/ZCCVXlGRiZKPJyPPRxyIFWeXLQBXJBKiq/3divEAN6ZwM200Qjm7EJBZeWm/PRWVCbYK7s7u2l4XaCz+lzgOfMfhMonXr7TWzeZb98dbgIzBT8Ub8eYYUqfZ4rVJ/MDbIDgPqTulJ/xvntWAtjIisqnwxOkGz0n077FARoY79GdA6HPE4rOy196NiMWHTZlSSApcOgXpy/fHV2joaNKu3ffsAnRcBf4K/6NcIG6tIxk3HyoXPjASqfUgXbYN5PzpL2njkR9QMjeDTVHDTCgRuxOegjoO0FvKzP/t/gmVdI24+G7NIe8JX6Wv3dDyldMA+4YB5wwTygtd+dwRqaTqrLb1l73zTSN52CNpnHuQOYPsDblybgxfkXh/oVtr+N1DEBJdhRJyd/Bd/q1z+cbNrD17iVKyajcnv9arhOkRPgsruuD6DmNPwpDNrLw2CoTgHni4yALr0L29+tiKAEIPn868ejx//8rpWP3OEOl5On9OwpcQm0MhafP/ey8f1uvDNIgGLQG8z4YO99ENgg95etwv4uYJYY8fUGHYH6j6fscHFZMftlAl9i+9XL73X3N/n+ZStOzfVfRvYXhrbdKOpEgVQTg/wsDuDD3kwOfQNMTJ5y+/ltUDWLunyxnRF46IqlBzGMY4X7inggREFioIyMjIyMHWCIB6ZNKAcXseo3vLTQTkVE7348dlwJJSz0+wLfmi8BhZqfw3D4ww/wHVLnEd5/fgYvXsDZ3MlsvYUbbnDjDZ3MN3TJG4+bxjAaDl8TBri9qxEw1ccao2wTNAMLHo2f+sjrXwb/9qHoYqgPMBXJTVfOpmrZH23y6uvo0LHSyY6fHGwKfHJlAuMFvObjDYrIqxBgQi20h7Hd/nYVLmno+eaNUm/eeH2GCuopntnhBJAlI2AHo9CCh1I1QxUdAbqqGY9BBLwyc3W4wYVhvY8A4BoIc1l5M7vnPWphZW9/Ses3n37y9a0uGqFwFQZsQQbd386DogpgEk+dzynsAZMJXq8+ns9NeukJ0PYrNATGGefJQlhkLo7DTXr+y3bNiOsDvrXTz/C2q1DXZH84iRNwrP88Nj+u2DjYEE6RBxD9Knj16ujVHC67A7422o02RwD3gB+t7EblWvu9geOFxSnd3ROmT+nJyQkhoPlsxVONc/3TEdBos+jtA+ZzcwHgTvD1cDjaYCcItA8w9i88A8b+mqSjc6Pvqd998QguEQPmQMeo23ODN86+p0/bn1buBkT6+oBhNZ/PYY4ZAHYb3PRd4LkZmPX68NRtMZn4ASvdA+qf0jMA5MP9eeg28Nug9QiLnj5A33U1MAES6xHAUNpz/9zFAYE1gqQDMT3G6xI9pwdw/aIgKoHCS1YGlRnSq9yCjdXjgN3j+N27YyROHxmuNAeNKPpYuXIyIyMjYy0M8eros59MF/PT2c602T7eA7zvhJ9dr/vzDjXaLp4Yc5+0wllzxzHv3gdmMMM7/CcQzKgVBqYTmFn+Z+mKm8J7k0A5F/jgCfjQ1WBhQyiOqD0lYuqBb+AyzMw9Ha2G3m6c8qQx+AlqnIceQp+Sb6i9UyQWbhr54+AjnZ0VzW2TAN0DmBT6PWmc6jDBE2PK2u+nF43dyP7Q0t1pOcX2fdRvH0mF2Q4JqN35rnHjVIeaXfIAVyUuw/aHCCiJy9iF5l1621zweI8KZrPZ9iJdb7DXJ3US0OSrtZ10imt7wHY7QesAzUMz1oZ3noB3qFJ/H18j97FYuw8QDN4oeKf30osvcSW2ExLo+VcbuAuo/sUIm8fMG9xocO3Ea19J9gFYivnHJ2KnyfovZlgW3v6ySx32abQiIyMjIyPjhlFDTLxpwIgFMnTp6A3g4IDKNY+stkwAMAoIAbasxBXqUWneSAWTMjt50lTqT29rFjvXohjsDNm2YPXDFlICmrJOZ3t6tHm8AiEAl0sCeLIIorIRt+cFbew/QRsoAXb4o1XSfoywzm0FTMAoYBNvLyFu8v8HpLBtD1iKgC17wHb7AI6d9wFbvguAIGTHd4E9wG7jgIyMjIyM+434c2R3HeV/Ffx6jtZu6ijl8h59T655jhR+rdHzDOP6beABCheb8O8/WFXeOyzgf5oAhVYnKxP7CwaAf1afJu8bSrhS6tdaXeGnrRenOqOlz9d6QwYnA/3TLd+GE7qe3chA5YF5DfY0vK3adfOX/gyNp2BW25MHdxAB9qvRiiP3/XpQQFGYDU4+Mi///XumXG8pjvaUAOsBGlf4jJt+YYEzeEzAdw06F19R3juM7D1wita86GR0CKfDHgLuXCc4Bri6vMLdfjMc4VNSUNsdodo2xu/1+Xl/K5+az8jIyMhYG/z5gJTMF1GtKq/a3rpyCvz5gJTMl9GtKq/a3rpyCmfQ4WwZmS+kXFVetb115ST48wEf/AGcfG1iw+tWbpbS2vJ3nQxcVr3lH3z5h972FUTLzYpOVk7l5hD+eYcYwDcAnewOotrZ4OtrPDucqi/LRX0/RR4qx7Nn4U8g+qjffvuN6Gf+nC85vwauHjaYyubqvWYKY4VEfSUMitdnBCT1Ue63R5439m+OgCn6DroAAaHPVQxKth/wkJgHmG8bmQMsT0D6EjDfvhVRKO3ywOQUgRA7nmL1uawZmHf1k+DPBwQ6NdcJ+k6Md1LA5f5ONdhJ8vZ5J0vLHT99srkGOjmJbd/G1r2Nriqnse1AZt1AalU5jW2HsuuG0qvKGRkZGRkZGRG0gcONyXsP9v8D0/IdJADiBNiXl3327WRGgOL/9HC/0XwlIURkRhC4tz6Z/fu7fUf2gHvfB9z3u0BGRkZGRkbGplHcnkgguQoSqtUXuhbs/wPtMwqV0HUJAvj5vk32b8IDuL23yn7qAXZ5u32hbRX7d3o82Df1FZXvbh9QOfhyxldr/+3xgXU9oKmvsHyr7F/XA269/eveBXrsv7N9QALe/tvjA0kPWAXGbvebkbHn+D/J5nMcHzx1UAAAAABJRU5ErkJggg==) !important}.admin-color-fresh .ui-datepicker-header,.wp-customizer .ui-datepicker-header{background-color:#23282d !important;color:white !important}.admin-color-fresh .ui-datepicker td .ui-state-active,.wp-customizer .ui-datepicker td .ui-state-active{background-color:#007db9 !important;color:white !important}.admin-color-fresh .ui-datepicker td .ui-state-hover,.wp-customizer .ui-datepicker td .ui-state-hover{color:#007db9 !important}.admin-color-fresh .ui-datepicker td .ui-state-highlight,.wp-customizer .ui-datepicker td .ui-state-highlight{background:#0073aa !important;border:1px solid #23282d !important;color:white !important}.admin-color-fresh .redux-container-switch .cb-disable,.admin-color-fresh .redux-container-switch .cb-enable,.admin-color-fresh .ui-state-default,.admin-color-fresh .ui-widget-content .ui-state-default,.admin-color-fresh .ui-widget-header .ui-state-default,.wp-customizer .redux-container-switch .cb-disable,.wp-customizer .redux-container-switch .cb-enable,.wp-customizer .ui-state-default,.wp-customizer .ui-widget-content .ui-state-default,.wp-customizer .ui-widget-header .ui-state-default{background-color:#f5f5f5 !important;background-image:-khtml-gradient(linear, left top, left bottom, from(#f8f8f8), to(#f5f5f5)) !important;background-image:-moz-linear-gradient(top, #f8f8f8, #f5f5f5) !important;background-image:-ms-linear-gradient(top, #f8f8f8, #f5f5f5) !important;background-image:-webkit-gradient(linear, left top, left bottom, color-stop(0%, #f8f8f8), color-stop(100%, #f5f5f5)) !important;background-image:-webkit-linear-gradient(top, #f8f8f8, #f5f5f5) !important;background-image:-o-linear-gradient(top, #f8f8f8, #f5f5f5) !important;background-image:-linear-gradient(top, #f8f8f8, #f5f5f5) !important;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#f8f8f8', endColorstr='#f5f5f5', GradientType=0) !important;border-color:#ccc !important}.admin-color-fresh .ui-datepicker td .ui-state-active,.wp-customizer .ui-datepicker td .ui-state-active{color:black !important;font-weight:700 !important;background:white !important}.admin-color-fresh .redux-container-switch .cb-disable.selected,.wp-customizer .redux-container-switch .cb-disable.selected{background-color:#646464 !important;background-image:-khtml-gradient(linear, left top, left bottom, from(#929292), to(#646464)) !important;background-image:-moz-linear-gradient(top, #929292, #646464) !important;background-image:-ms-linear-gradient(top, #929292, #646464) !important;background-image:-webkit-gradient(linear, left top, left bottom, color-stop(0%, #929292), color-stop(100%, #646464)) !important;background-image:-webkit-linear-gradient(top, #929292, #646464) !important;background-image:-o-linear-gradient(top, #929292, #646464) !important;background-image:-linear-gradient(top, #929292, #646464) !important;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#929292', endColorstr='#646464', GradientType=0) !important;border-color:#767676 !important}.admin-color-fresh .redux-container-switch .cb-enable.selected,.admin-color-fresh .redux-field-container .ui-buttonset .ui-state-active,.wp-customizer .redux-container-switch .cb-enable.selected,.wp-customizer .redux-field-container .ui-buttonset .ui-state-active{background-color:#0073aa !important;background-image:-khtml-gradient(linear, left top, left bottom, from(#008bce), to(#0073aa)) !important;background-image:-moz-linear-gradient(top, #008bce, #0073aa) !important;background-image:-ms-linear-gradient(top, #008bce, #0073aa) !important;background-image:-webkit-gradient(linear, left top, left bottom, color-stop(0%, #008bce), color-stop(100%, #0073aa)) !important;background-image:-webkit-linear-gradient(top, #008bce, #0073aa) !important;background-image:-o-linear-gradient(top, #008bce, #0073aa) !important;background-image:-linear-gradient(top, #008bce, #0073aa) !important;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#008bce', endColorstr='#0073aa', GradientType=0) !important;border-color:#003f5d !important;border-color:#005077 !important;-webkit-box-shadow:inset 0 1px 0 #00a7f6,0 1px 0 rgba(0,0,0,0.15) !important;box-shadow:inset 0 1px 0 #00a7f6,0 1px 0 rgba(0,0,0,0.15) !important}.admin-color-fresh #redux-header,.wp-customizer #redux-header{background:#23282d;border-color:#0073aa}.admin-color-fresh #redux-header .display_header span,.wp-customizer #redux-header .display_header span{color:#a0a5aa}.admin-color-fresh .redux-sidebar .redux-group-menu li.active.hasSubSections a,.wp-customizer .redux-sidebar .redux-group-menu li.active.hasSubSections a{position:relative}.admin-color-fresh .redux-sidebar .redux-group-menu li.active.hasSubSections a:after,.wp-customizer .redux-sidebar .redux-group-menu li.active.hasSubSections a:after{right:0;border:solid 8px transparent;content:"\0020";height:0;width:0;position:absolute;pointer-events:none;border-right-color:#fff;top:50%;margin-top:-8px}.admin-color-fresh .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li a:after,.wp-customizer .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li a:after{border:0 none !important;content:"\0020" !important}.admin-color-fresh .redux-sidebar .redux-group-menu li.hasSubSections .redux-menu-error,.wp-customizer .redux-sidebar .redux-group-menu li.hasSubSections .redux-menu-error{display:none;margin-right:5px}.admin-color-fresh .redux-sidebar .redux-group-menu li.hasSubSections a.hasError .extraIconSubsections,.wp-customizer .redux-sidebar .redux-group-menu li.hasSubSections a.hasError .extraIconSubsections{background-color:#b94a48;color:#f2dede}.admin-color-fresh .redux-sidebar .redux-group-menu li.hasSubSections a .extraIconSubsections,.wp-customizer .redux-sidebar .redux-group-menu li.hasSubSections a .extraIconSubsections{border-radius:10px;-moz-border-radius:10px;-webkit-border-radius:10px;border:0 solid transparent;float:right;font-size:9px;height:9px;line-height:9px;margin-right:5px;padding:6px 7px 4px 7px;width:5px}.admin-color-fresh .redux-sidebar .redux-group-menu li.active a .extraIconSubsections,.admin-color-fresh .redux-sidebar .redux-group-menu li.activeChild a .extraIconSubsections,.wp-customizer .redux-sidebar .redux-group-menu li.active a .extraIconSubsections,.wp-customizer .redux-sidebar .redux-group-menu li.activeChild a .extraIconSubsections{display:none}.admin-color-fresh .redux-sidebar .redux-group-menu li.active.hasSubSections .redux-menu-error,.admin-color-fresh .redux-sidebar .redux-group-menu li.activeChild.hasSubSections .redux-menu-error,.wp-customizer .redux-sidebar .redux-group-menu li.active.hasSubSections .redux-menu-error,.wp-customizer .redux-sidebar .redux-group-menu li.activeChild.hasSubSections .redux-menu-error{display:block}.admin-color-fresh .redux-sidebar .redux-group-menu li.active.hasSubSections .subsection .redux-menu-error,.admin-color-fresh .redux-sidebar .redux-group-menu li.activeChild.hasSubSections .subsection .redux-menu-error,.wp-customizer .redux-sidebar .redux-group-menu li.active.hasSubSections .subsection .redux-menu-error,.wp-customizer .redux-sidebar .redux-group-menu li.activeChild.hasSubSections .subsection .redux-menu-error{margin-right:2px}.admin-color-fresh .redux-sidebar .redux-group-menu li.active,.admin-color-fresh .redux-sidebar .redux-group-menu li.activeChild,.wp-customizer .redux-sidebar .redux-group-menu li.active,.wp-customizer .redux-sidebar .redux-group-menu li.activeChild{border-left:0 none}.admin-color-fresh .redux-sidebar .redux-group-menu li.active a,.admin-color-fresh .redux-sidebar .redux-group-menu li.activeChild a,.wp-customizer .redux-sidebar .redux-group-menu li.active a,.wp-customizer .redux-sidebar .redux-group-menu li.activeChild a{color:#23282d}.admin-color-fresh .redux-sidebar .redux-group-menu li.active.hasSubSections .active a:after,.admin-color-fresh .redux-sidebar .redux-group-menu li.activeChild.hasSubSections .active a:after,.wp-customizer .redux-sidebar .redux-group-menu li.active.hasSubSections .active a:after,.wp-customizer .redux-sidebar .redux-group-menu li.activeChild.hasSubSections .active a:after{right:0;border:solid 8px transparent;content:"\0020";height:0;width:0;position:absolute;pointer-events:none;border-right-color:#fff;top:50%;margin-top:-8px}.admin-color-fresh .redux-sidebar .redux-group-menu li.active.hasSubSections a,.admin-color-fresh .redux-sidebar .redux-group-menu li.activeChild.hasSubSections a,.wp-customizer .redux-sidebar .redux-group-menu li.active.hasSubSections a,.wp-customizer .redux-sidebar .redux-group-menu li.activeChild.hasSubSections a{-webkit-transition:all 0.2s;-moz-transition:all 0.2s;transition:all 0.2s;color:#fff;width:auto;border-bottom:0}.admin-color-fresh .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li,.admin-color-fresh .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li,.wp-customizer .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li,.wp-customizer .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li{border-top:0 none !important}.admin-color-fresh .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li.active a:hover,.admin-color-fresh .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li.active a:hover,.wp-customizer .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li.active a:hover,.wp-customizer .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li.active a:hover{color:#fff}.admin-color-fresh .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li a,.admin-color-fresh .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li a,.wp-customizer .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li a,.wp-customizer .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li a{width:auto;border-top:0 !important;padding:7px;color:#fff;padding-left:15px;-webkit-transition:all 0.2;-moz-transition:all 0.2;-ms-transition:all 0.2;-o-transition:all 0.2;transition:all 0.2}.admin-color-fresh .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li a:hover,.admin-color-fresh .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li a:hover,.wp-customizer .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li a:hover,.wp-customizer .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li a:hover{color:#1e8cbe;background:#0d0e10}.admin-color-fresh .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li a span.group_title,.admin-color-fresh .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li a span.group_title,.wp-customizer .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li a span.group_title,.wp-customizer .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li a span.group_title{padding-left:5px !important}.admin-color-fresh .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li.hasIcon a,.admin-color-fresh .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li.hasIcon a,.wp-customizer .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li.hasIcon a,.wp-customizer .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li.hasIcon a{padding-left:14px}.admin-color-fresh .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li.hasIcon a span.group_title,.admin-color-fresh .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li.hasIcon a span.group_title,.wp-customizer .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li.hasIcon a span.group_title,.wp-customizer .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li.hasIcon a span.group_title{padding-left:30px !important}.admin-color-fresh .redux-sidebar .redux-group-menu li.active.hasSubSections a,.wp-customizer .redux-sidebar .redux-group-menu li.active.hasSubSections a{background:#0073aa}.admin-color-fresh .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li a,.wp-customizer .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li a{background:#23282d}.admin-color-fresh .redux-sidebar .redux-group-menu li.activeChild.hasSubSections a,.wp-customizer .redux-sidebar .redux-group-menu li.activeChild.hasSubSections a{background:#a0a5aa;text-shadow:1px 1px #54595d}.admin-color-fresh .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li a,.wp-customizer .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li a{background:#23282d;text-shadow:none}.admin-color-fresh .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li.active a,.wp-customizer .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li.active a{background:#0073aa;text-shadow:1px 1px #002e44}.admin-color-fresh .redux-container-image_select .redux-image-select-selected img,.wp-customizer .redux-container-image_select .redux-image-select-selected img{border-color:#0073aa}.admin-color-fresh #redux-footer #redux-share a,.wp-customizer #redux-footer #redux-share a{color:#0073aa}.admin-color-fresh #redux-footer #redux-share a:hover,.wp-customizer #redux-footer #redux-share a:hover{color:#002e44}.admin-color-fresh .select2-results .select2-highlighted,.wp-customizer .select2-results .select2-highlighted{background:#0073aa}.admin-color-fresh .select2-drop-active,.admin-color-fresh .select2-container-multi.select2-container-active .select2-choices,.admin-color-fresh .select2-drop.select2-drop-above.select2-drop-active,.admin-color-fresh .select2-container-active .select2-choice,.admin-color-fresh .select2-container-active .select2-choices,.admin-color-fresh .select2-dropdown-open.select2-drop-above .select2-choice,.admin-color-fresh .select2-dropdown-open.select2-drop-above .select2-choices,.wp-customizer .select2-drop-active,.wp-customizer .select2-container-multi.select2-container-active .select2-choices,.wp-customizer .select2-drop.select2-drop-above.select2-drop-active,.wp-customizer .select2-container-active .select2-choice,.wp-customizer .select2-container-active .select2-choices,.wp-customizer .select2-dropdown-open.select2-drop-above .select2-choice,.wp-customizer .select2-dropdown-open.select2-drop-above .select2-choices{border-color:#0073aa}.admin-color-fresh .select2-dropdown-open.select2-drop-above .select2-choice,.admin-color-fresh .select2-dropdown-open.select2-drop-above .select2-choices,.wp-customizer .select2-dropdown-open.select2-drop-above .select2-choice,.wp-customizer .select2-dropdown-open.select2-drop-above .select2-choices{border-top:inherit}.admin-color-fresh .noUi-connect,.wp-customizer .noUi-connect{background-color:#007db9 !important;background-image:-khtml-gradient(linear, left top, left bottom, from(#0095dd), to(#007db9)) !important;background-image:-moz-linear-gradient(top, #0095dd, #007db9) !important;background-image:-ms-linear-gradient(top, #0095dd, #007db9) !important;background-image:-webkit-gradient(linear, left top, left bottom, color-stop(0%, #0095dd), color-stop(100%, #007db9)) !important;background-image:-webkit-linear-gradient(top, #0095dd, #007db9) !important;background-image:-o-linear-gradient(top, #0095dd, #007db9) !important;background-image:-linear-gradient(top, #0095dd, #007db9) !important;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#0095dd', endColorstr='#007db9', GradientType=0) !important}.admin-color-light .button.ui-datepicker-current,.admin-color-light button.ui-datepicker-close{background-color:#04b0db !important}.admin-color-light .ui-datepicker-buttonpane button.ui-datepicker-current{background:#0384a4 !important;color:white !important;border:1px solid #013340 !important}.admin-color-light .ui-datepicker-header .ui-icon{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAQAAAADwCAMAAADYSUr5AAAA7VBMVEX8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vywC3+8AAAATnRSTlMAGBAyBAhQv4OZLiJUcEBmYBoSzQwgPBZCSEoeWiYwUiyFNIeBw2rJz8c4RBy9uXyrtaWNqa2zKP2fJO8KBgKPo2KVoa9s351GPm5+kWho0kj9AAAPhUlEQVR4nO1djWLbthEGyUiq5YSSLXtp7FpLOmfzkmxr126tmi2p03RJ1/Xe/3EGgARxPyAgRbIk2/hkSz4CJO4+HsE7AJSVysjI2AMUUOxahZ2iANhzBtZWr4BoIRSYAVN5u4QwDwQDRbcwfUi5KS3wFuDmFnQLa4Dtb//cqktwD5QEFFwfUs7PoCCA7y4bEJVFizcIob8KmhAplwwqVjt+9FBl3uINQniwEiryEyw9JHqGpQdEFNi+B4QQ7QOiHhysIPoAxUqxvdvvA9K42bsAv4S2fxfYOe57IJSRkZGRkZGxx7jxSHDHcRBXQMTyIjInBgHwBJ/bEx8PEANC+uhbpSSggCBAVODVabpI1S/k4WLZpTn6NpMhoX9Y40hxYERFpMcqUs4AloCtDQdID1YhnyXZ2hLjAYWiO9Dy1PDB7tPhIqLx+uMB8grZaR+Qxl2/C2RkZGRkZGRk7A7rBf7J0DR5/LUTjzUPIPSPGvQJiVJiB7kcQCiUOJrcFNtDZIf2xarQ3aGvLNxAVIFAabz90BFiBIlycTBhgWwOWCH0FLYHlPqwHaCvcIn2ZbosCevfPTRiFFcgvHukCjWwrc3GrGh1fsAof8EaUReKXkCB4/MzFNo97qLpFiKFYv/kNR5YQxQbQEofkZ2OuEOHqqT6gFTpru8CN7x/+jaZkZGRkZGRcV+x/rLUNcMMqUAscgnFocmpqkTzqymwVAPxfJ5PnIUUQOUKT04tEdWZyv3JCQSn96WS4pD97QfyW25A7NhSAbyhmVj0FEltA4vdiygBibXhoUYgykCUP7HwPTDeEqAIcHVMkZg7Zx4k0uFANs63hPQXCoRLAwdgGsr9Az7Qv7sgQGgg1aPl/BJLExBWgG4RFRLFImGmIquPC/klEGyCG0AuAXaJJC+B8FVe9NYQDEcXB8g6AQcjYJ1goJIggHWCrFR0S6kRHN5+4BzFi8NaoN35NRxUvL+JJdZr7PV4wK6fj8nIyMjIyNhr3OxdXAYq7FHZwB6bDSzSh4sF0utChqo0NAvaT1hLzXwFinmCzmeDucEQK18TTaQoFgP7bNC+RZ4OT4T6gQogDFYk+1QxQlj19QGSAWKiLYp8P0Ag1Gbz1ULfWHLg9iUnQNK5QQJcukm04blKLH2GgEJCY+HzXAZWCvHKco3Bp6MIaCjSXXRJyOxeqhnzEaF93MfFGW/O16ZvDL5TM4MJIjujz/cHypkQuuzRwWJ93BKdIt+wCRAPl9kpe2Ikkb2mFgGlxh/i40d3EHfdvoyMjIyMu43ylt/IAmGHnN5iIt7wKfbv01RAcJqFRl9lcjYQSnbQqKgC4fYOwSJt6N6trE0twZ9kN/PqNpTQeICvr4TLsDYC06U7BMjshS+v1/aT7IwQYD5LcgRQXMT2FrBfBLjZ6151jDElk9tPFfpUgk2yregusX25BJbwAFEfM+YI6vGAti4bTtizB+TjfQCrERyhKb2X8D6A9wX75P4t4neBYJeP6pdhg/gQl8MWvytzeSTjgOQBynQdh/iXKdxOrGJ/RkZGRsb9QmXihGr5+g8GGg9uTh+KoVZuNIzV+CwRucFBEyr1mVjx4irOxwM1BhirB6Q+2eNQi4eqR+aF6mELtoMzCR7V9RAFe/ZvQogNiyY8FPSUTFsLp8TeTmMui5mtw7bcaT0Yw2AA4wFRQIlkgq+1DQrNhkmoxS5Jq+u6bMAIGRECEANgXHTgWzwgBOhDH2l0oTQ4D8D5NMktBgNywAEMjo8rwATMZrPY7JGxBoJCkIBDQiAY09EGTUiBCWkUpISfGPR5AAwBfZiG2z7Ayc1yeKTxid39xBNwfHr4O0LA48ePFTvhYrF1r4tyAoz9n2MCqEuBtp/6GDR0oAYfG/R6wJExHYZHfhygsv7fEWCOj4bYmsP5A+pL4MkTfAnMlD4F+r3bobKvTyTA2P/w7PN+Agq2QW8piqMCpTBwenoKvX0AHGkGtP2YAPvTEWA7QUTAudn7/NxtOG46wWNmDtpBEkBzN7rBEvAFHp+YTB/q97qPAN4gHFqgBi8uLsC7qPCA6mg41G/+ErByPwEXDdoNxRhOx+M5jPEzQugS0ht+b1/Y3gEnYMAIAOIBE29/hIDucE8tmMsNOgK4B1RHFu4UCRlMHzv0xzcajcfdXWDs2h8TArBCkoDUJYDLmz6w7ip3BFS0ve5wTRwAn6keMA9I3QYbfSZ0DKbyt+7OXjGI1idPcfNyAyfAMlCrzaGqphYrxHocLHRJVycnfGUcbtT+jIyMjIw9x7Nn8fJSzG0TmFtO8rZT+XT3S3ub+tKJbbLd5diTVp50+zahyeHSslJ/YPrU0fuazrZO2CZ92/ZCCVXlGRiZKPJyPPRxyIFWeXLQBXJBKiq/3divEAN6ZwM200Qjm7EJBZeWm/PRWVCbYK7s7u2l4XaCz+lzgOfMfhMonXr7TWzeZb98dbgIzBT8Ub8eYYUqfZ4rVJ/MDbIDgPqTulJ/xvntWAtjIisqnwxOkGz0n077FARoY79GdA6HPE4rOy196NiMWHTZlSSApcOgXpy/fHV2joaNKu3ffsAnRcBf4K/6NcIG6tIxk3HyoXPjASqfUgXbYN5PzpL2njkR9QMjeDTVHDTCgRuxOegjoO0FvKzP/t/gmVdI24+G7NIe8JX6Wv3dDyldMA+4YB5wwTygtd+dwRqaTqrLb1l73zTSN52CNpnHuQOYPsDblybgxfkXh/oVtr+N1DEBJdhRJyd/Bd/q1z+cbNrD17iVKyajcnv9arhOkRPgsruuD6DmNPwpDNrLw2CoTgHni4yALr0L29+tiKAEIPn868ejx//8rpWP3OEOl5On9OwpcQm0MhafP/ey8f1uvDNIgGLQG8z4YO99ENgg95etwv4uYJYY8fUGHYH6j6fscHFZMftlAl9i+9XL73X3N/n+ZStOzfVfRvYXhrbdKOpEgVQTg/wsDuDD3kwOfQNMTJ5y+/ltUDWLunyxnRF46IqlBzGMY4X7inggREFioIyMjIyMHWCIB6ZNKAcXseo3vLTQTkVE7348dlwJJSz0+wLfmi8BhZqfw3D4ww/wHVLnEd5/fgYvXsDZ3MlsvYUbbnDjDZ3MN3TJG4+bxjAaDl8TBri9qxEw1ccao2wTNAMLHo2f+sjrXwb/9qHoYqgPMBXJTVfOpmrZH23y6uvo0LHSyY6fHGwKfHJlAuMFvObjDYrIqxBgQi20h7Hd/nYVLmno+eaNUm/eeH2GCuopntnhBJAlI2AHo9CCh1I1QxUdAbqqGY9BBLwyc3W4wYVhvY8A4BoIc1l5M7vnPWphZW9/Ses3n37y9a0uGqFwFQZsQQbd386DogpgEk+dzynsAZMJXq8+ns9NeukJ0PYrNATGGefJQlhkLo7DTXr+y3bNiOsDvrXTz/C2q1DXZH84iRNwrP88Nj+u2DjYEE6RBxD9Knj16ujVHC67A7422o02RwD3gB+t7EblWvu9geOFxSnd3ROmT+nJyQkhoPlsxVONc/3TEdBos+jtA+ZzcwHgTvD1cDjaYCcItA8w9i88A8b+mqSjc6Pvqd998QguEQPmQMeo23ODN86+p0/bn1buBkT6+oBhNZ/PYY4ZAHYb3PRd4LkZmPX68NRtMZn4ASvdA+qf0jMA5MP9eeg28Nug9QiLnj5A33U1MAES6xHAUNpz/9zFAYE1gqQDMT3G6xI9pwdw/aIgKoHCS1YGlRnSq9yCjdXjgN3j+N27YyROHxmuNAeNKPpYuXIyIyMjYy0M8eros59MF/PT2c602T7eA7zvhJ9dr/vzDjXaLp4Yc5+0wllzxzHv3gdmMMM7/CcQzKgVBqYTmFn+Z+mKm8J7k0A5F/jgCfjQ1WBhQyiOqD0lYuqBb+AyzMw9Ha2G3m6c8qQx+AlqnIceQp+Sb6i9UyQWbhr54+AjnZ0VzW2TAN0DmBT6PWmc6jDBE2PK2u+nF43dyP7Q0t1pOcX2fdRvH0mF2Q4JqN35rnHjVIeaXfIAVyUuw/aHCCiJy9iF5l1621zweI8KZrPZ9iJdb7DXJ3US0OSrtZ10imt7wHY7QesAzUMz1oZ3noB3qFJ/H18j97FYuw8QDN4oeKf30osvcSW2ExLo+VcbuAuo/sUIm8fMG9xocO3Ea19J9gFYivnHJ2KnyfovZlgW3v6ySx32abQiIyMjIyPjhlFDTLxpwIgFMnTp6A3g4IDKNY+stkwAMAoIAbasxBXqUWneSAWTMjt50lTqT29rFjvXohjsDNm2YPXDFlICmrJOZ3t6tHm8AiEAl0sCeLIIorIRt+cFbew/QRsoAXb4o1XSfoywzm0FTMAoYBNvLyFu8v8HpLBtD1iKgC17wHb7AI6d9wFbvguAIGTHd4E9wG7jgIyMjIyM+434c2R3HeV/Ffx6jtZu6ijl8h59T655jhR+rdHzDOP6beABCheb8O8/WFXeOyzgf5oAhVYnKxP7CwaAf1afJu8bSrhS6tdaXeGnrRenOqOlz9d6QwYnA/3TLd+GE7qe3chA5YF5DfY0vK3adfOX/gyNp2BW25MHdxAB9qvRiiP3/XpQQFGYDU4+Mi///XumXG8pjvaUAOsBGlf4jJt+YYEzeEzAdw06F19R3juM7D1wita86GR0CKfDHgLuXCc4Bri6vMLdfjMc4VNSUNsdodo2xu/1+Xl/K5+az8jIyMhYG/z5gJTMF1GtKq/a3rpyCvz5gJTMl9GtKq/a3rpyCmfQ4WwZmS+kXFVetb115ST48wEf/AGcfG1iw+tWbpbS2vJ3nQxcVr3lH3z5h972FUTLzYpOVk7l5hD+eYcYwDcAnewOotrZ4OtrPDucqi/LRX0/RR4qx7Nn4U8g+qjffvuN6Gf+nC85vwauHjaYyubqvWYKY4VEfSUMitdnBCT1Ue63R5439m+OgCn6DroAAaHPVQxKth/wkJgHmG8bmQMsT0D6EjDfvhVRKO3ywOQUgRA7nmL1uawZmHf1k+DPBwQ6NdcJ+k6Md1LA5f5ONdhJ8vZ5J0vLHT99srkGOjmJbd/G1r2Nriqnse1AZt1AalU5jW2HsuuG0qvKGRkZGRkZGRG0gcONyXsP9v8D0/IdJADiBNiXl3327WRGgOL/9HC/0XwlIURkRhC4tz6Z/fu7fUf2gHvfB9z3u0BGRkZGRkbGplHcnkgguQoSqtUXuhbs/wPtMwqV0HUJAvj5vk32b8IDuL23yn7qAXZ5u32hbRX7d3o82Df1FZXvbh9QOfhyxldr/+3xgXU9oKmvsHyr7F/XA269/eveBXrsv7N9QALe/tvjA0kPWAXGbvebkbHn+D/J5nMcHzx1UAAAAABJRU5ErkJggg==) !important}.admin-color-light .ui-datepicker-header{background-color:#888 !important;color:white !important}.admin-color-light .ui-datepicker td .ui-state-active{background-color:#04b0db !important;color:white !important}.admin-color-light .ui-datepicker td .ui-state-hover{color:#04b0db !important}.admin-color-light .ui-datepicker td .ui-state-highlight{background:#04a4cc !important;border:1px solid #888 !important;color:white !important}.admin-color-light .redux-container-switch .cb-disable,.admin-color-light .redux-container-switch .cb-enable,.admin-color-light .ui-state-default,.admin-color-light .ui-widget-content .ui-state-default,.admin-color-light .ui-widget-header .ui-state-default{background-color:#f5f5f5 !important;background-image:-khtml-gradient(linear, left top, left bottom, from(#f8f8f8), to(#f5f5f5)) !important;background-image:-moz-linear-gradient(top, #f8f8f8, #f5f5f5) !important;background-image:-ms-linear-gradient(top, #f8f8f8, #f5f5f5) !important;background-image:-webkit-gradient(linear, left top, left bottom, color-stop(0%, #f8f8f8), color-stop(100%, #f5f5f5)) !important;background-image:-webkit-linear-gradient(top, #f8f8f8, #f5f5f5) !important;background-image:-o-linear-gradient(top, #f8f8f8, #f5f5f5) !important;background-image:-linear-gradient(top, #f8f8f8, #f5f5f5) !important;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#f8f8f8', endColorstr='#f5f5f5', GradientType=0) !important;border-color:#ccc !important}.admin-color-light .ui-datepicker td .ui-state-active{color:black !important;font-weight:700 !important;background:white !important}.admin-color-light .redux-container-switch .cb-disable.selected{background-color:#646464 !important;background-image:-khtml-gradient(linear, left top, left bottom, from(#929292), to(#646464)) !important;background-image:-moz-linear-gradient(top, #929292, #646464) !important;background-image:-ms-linear-gradient(top, #929292, #646464) !important;background-image:-webkit-gradient(linear, left top, left bottom, color-stop(0%, #929292), color-stop(100%, #646464)) !important;background-image:-webkit-linear-gradient(top, #929292, #646464) !important;background-image:-o-linear-gradient(top, #929292, #646464) !important;background-image:-linear-gradient(top, #929292, #646464) !important;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#929292', endColorstr='#646464', GradientType=0) !important;border-color:#767676 !important}.admin-color-light .redux-container-switch .cb-enable.selected,.admin-color-light .redux-field-container .ui-buttonset .ui-state-active{background-color:#04a4cc !important;background-image:-khtml-gradient(linear, left top, left bottom, from(#05c0ef), to(#04a4cc)) !important;background-image:-moz-linear-gradient(top, #05c0ef, #04a4cc) !important;background-image:-ms-linear-gradient(top, #05c0ef, #04a4cc) !important;background-image:-webkit-gradient(linear, left top, left bottom, color-stop(0%, #05c0ef), color-stop(100%, #04a4cc)) !important;background-image:-webkit-linear-gradient(top, #05c0ef, #04a4cc) !important;background-image:-o-linear-gradient(top, #05c0ef, #04a4cc) !important;background-image:-linear-gradient(top, #05c0ef, #04a4cc) !important;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#05c0ef', endColorstr='#04a4cc', GradientType=0) !important;border-color:#036881 !important;border-color:#037c9a !important;-webkit-box-shadow:inset 0 1px 0 #22cffb,0 1px 0 rgba(0,0,0,0.15) !important;box-shadow:inset 0 1px 0 #22cffb,0 1px 0 rgba(0,0,0,0.15) !important}.admin-color-light #redux-header{background:#888;border-color:#04a4cc}.admin-color-light #redux-header .display_header span{color:#e6e6e6}.admin-color-light .redux-sidebar .redux-group-menu li.active.hasSubSections a{position:relative}.admin-color-light .redux-sidebar .redux-group-menu li.active.hasSubSections a:after{right:0;border:solid 8px transparent;content:"\0020";height:0;width:0;position:absolute;pointer-events:none;border-right-color:#fff;top:50%;margin-top:-8px}.admin-color-light .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li a:after{border:0 none !important;content:"\0020" !important}.admin-color-light .redux-sidebar .redux-group-menu li.hasSubSections .redux-menu-error{display:none;margin-right:5px}.admin-color-light .redux-sidebar .redux-group-menu li.hasSubSections a.hasError .extraIconSubsections{background-color:#b94a48;color:#f2dede}.admin-color-light .redux-sidebar .redux-group-menu li.hasSubSections a .extraIconSubsections{border-radius:10px;-moz-border-radius:10px;-webkit-border-radius:10px;border:0 solid transparent;float:right;font-size:9px;height:9px;line-height:9px;margin-right:5px;padding:6px 7px 4px 7px;width:5px}.admin-color-light .redux-sidebar .redux-group-menu li.active a .extraIconSubsections,.admin-color-light .redux-sidebar .redux-group-menu li.activeChild a .extraIconSubsections{display:none}.admin-color-light .redux-sidebar .redux-group-menu li.active.hasSubSections .redux-menu-error,.admin-color-light .redux-sidebar .redux-group-menu li.activeChild.hasSubSections .redux-menu-error{display:block}.admin-color-light .redux-sidebar .redux-group-menu li.active.hasSubSections .subsection .redux-menu-error,.admin-color-light .redux-sidebar .redux-group-menu li.activeChild.hasSubSections .subsection .redux-menu-error{margin-right:2px}.admin-color-light .redux-sidebar .redux-group-menu li.active,.admin-color-light .redux-sidebar .redux-group-menu li.activeChild{border-left:0 none}.admin-color-light .redux-sidebar .redux-group-menu li.active a,.admin-color-light .redux-sidebar .redux-group-menu li.activeChild a{color:#888}.admin-color-light .redux-sidebar .redux-group-menu li.active.hasSubSections .active a:after,.admin-color-light .redux-sidebar .redux-group-menu li.activeChild.hasSubSections .active a:after{right:0;border:solid 8px transparent;content:"\0020";height:0;width:0;position:absolute;pointer-events:none;border-right-color:#fff;top:50%;margin-top:-8px}.admin-color-light .redux-sidebar .redux-group-menu li.active.hasSubSections a,.admin-color-light .redux-sidebar .redux-group-menu li.activeChild.hasSubSections a{-webkit-transition:all 0.2s;-moz-transition:all 0.2s;transition:all 0.2s;color:#fff;width:auto;border-bottom:0}.admin-color-light .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li,.admin-color-light .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li{border-top:0 none !important}.admin-color-light .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li.active a:hover,.admin-color-light .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li.active a:hover{color:#fff}.admin-color-light .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li a,.admin-color-light .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li a{width:auto;border-top:0 !important;padding:7px;color:#fff;padding-left:15px;-webkit-transition:all 0.2;-moz-transition:all 0.2;-ms-transition:all 0.2;-o-transition:all 0.2;transition:all 0.2}.admin-color-light .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li a:hover,.admin-color-light .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li a:hover{color:#0384a4;background:#6f6f6f}.admin-color-light .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li a span.group_title,.admin-color-light .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li a span.group_title{padding-left:5px !important}.admin-color-light .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li.hasIcon a,.admin-color-light .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li.hasIcon a{padding-left:14px}.admin-color-light .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li.hasIcon a span.group_title,.admin-color-light .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li.hasIcon a span.group_title{padding-left:30px !important}.admin-color-light .redux-sidebar .redux-group-menu li.active.hasSubSections a{background:#04a4cc}.admin-color-light .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li a{background:#888}.admin-color-light .redux-sidebar .redux-group-menu li.activeChild.hasSubSections a{background:#e6e6e6;text-shadow:1px 1px #9a9a9a}.admin-color-light .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li a{background:#888;text-shadow:none}.admin-color-light .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li.active a{background:#04a4cc;text-shadow:1px 1px #025468}.admin-color-light .redux-container-image_select .redux-image-select-selected img{border-color:#04a4cc}.admin-color-light #redux-footer #redux-share a{color:#04a4cc}.admin-color-light #redux-footer #redux-share a:hover{color:#025468}.admin-color-light .select2-results .select2-highlighted{background:#04a4cc}.admin-color-light .select2-drop-active,.admin-color-light .select2-container-multi.select2-container-active .select2-choices,.admin-color-light .select2-drop.select2-drop-above.select2-drop-active,.admin-color-light .select2-container-active .select2-choice,.admin-color-light .select2-container-active .select2-choices,.admin-color-light .select2-dropdown-open.select2-drop-above .select2-choice,.admin-color-light .select2-dropdown-open.select2-drop-above .select2-choices{border-color:#04a4cc}.admin-color-light .select2-dropdown-open.select2-drop-above .select2-choice,.admin-color-light .select2-dropdown-open.select2-drop-above .select2-choices{border-top:inherit}.admin-color-light .noUi-connect{background-color:#04b0db !important;background-image:-khtml-gradient(linear, left top, left bottom, from(#09cafa), to(#04b0db)) !important;background-image:-moz-linear-gradient(top, #09cafa, #04b0db) !important;background-image:-ms-linear-gradient(top, #09cafa, #04b0db) !important;background-image:-webkit-gradient(linear, left top, left bottom, color-stop(0%, #09cafa), color-stop(100%, #04b0db)) !important;background-image:-webkit-linear-gradient(top, #09cafa, #04b0db) !important;background-image:-o-linear-gradient(top, #09cafa, #04b0db) !important;background-image:-linear-gradient(top, #09cafa, #04b0db) !important;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#09cafa', endColorstr='#04b0db', GradientType=0) !important}.admin-color-blue .button.ui-datepicker-current,.admin-color-blue button.ui-datepicker-close{background-color:#509dba !important}.admin-color-blue .ui-datepicker-buttonpane button.ui-datepicker-current{background:#db9825 !important;color:white !important;border:1px solid #845c16 !important}.admin-color-blue .ui-datepicker-header .ui-icon{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAQAAAADwCAMAAADYSUr5AAAA7VBMVEX8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vywC3+8AAAATnRSTlMAGBAyBAhQv4OZLiJUcEBmYBoSzQwgPBZCSEoeWiYwUiyFNIeBw2rJz8c4RBy9uXyrtaWNqa2zKP2fJO8KBgKPo2KVoa9s351GPm5+kWho0kj9AAAPhUlEQVR4nO1djWLbthEGyUiq5YSSLXtp7FpLOmfzkmxr126tmi2p03RJ1/Xe/3EGgARxPyAgRbIk2/hkSz4CJO4+HsE7AJSVysjI2AMUUOxahZ2iANhzBtZWr4BoIRSYAVN5u4QwDwQDRbcwfUi5KS3wFuDmFnQLa4Dtb//cqktwD5QEFFwfUs7PoCCA7y4bEJVFizcIob8KmhAplwwqVjt+9FBl3uINQniwEiryEyw9JHqGpQdEFNi+B4QQ7QOiHhysIPoAxUqxvdvvA9K42bsAv4S2fxfYOe57IJSRkZGRkZGxx7jxSHDHcRBXQMTyIjInBgHwBJ/bEx8PEANC+uhbpSSggCBAVODVabpI1S/k4WLZpTn6NpMhoX9Y40hxYERFpMcqUs4AloCtDQdID1YhnyXZ2hLjAYWiO9Dy1PDB7tPhIqLx+uMB8grZaR+Qxl2/C2RkZGRkZGRk7A7rBf7J0DR5/LUTjzUPIPSPGvQJiVJiB7kcQCiUOJrcFNtDZIf2xarQ3aGvLNxAVIFAabz90BFiBIlycTBhgWwOWCH0FLYHlPqwHaCvcIn2ZbosCevfPTRiFFcgvHukCjWwrc3GrGh1fsAof8EaUReKXkCB4/MzFNo97qLpFiKFYv/kNR5YQxQbQEofkZ2OuEOHqqT6gFTpru8CN7x/+jaZkZGRkZGRcV+x/rLUNcMMqUAscgnFocmpqkTzqymwVAPxfJ5PnIUUQOUKT04tEdWZyv3JCQSn96WS4pD97QfyW25A7NhSAbyhmVj0FEltA4vdiygBibXhoUYgykCUP7HwPTDeEqAIcHVMkZg7Zx4k0uFANs63hPQXCoRLAwdgGsr9Az7Qv7sgQGgg1aPl/BJLExBWgG4RFRLFImGmIquPC/klEGyCG0AuAXaJJC+B8FVe9NYQDEcXB8g6AQcjYJ1goJIggHWCrFR0S6kRHN5+4BzFi8NaoN35NRxUvL+JJdZr7PV4wK6fj8nIyMjIyNhr3OxdXAYq7FHZwB6bDSzSh4sF0utChqo0NAvaT1hLzXwFinmCzmeDucEQK18TTaQoFgP7bNC+RZ4OT4T6gQogDFYk+1QxQlj19QGSAWKiLYp8P0Ag1Gbz1ULfWHLg9iUnQNK5QQJcukm04blKLH2GgEJCY+HzXAZWCvHKco3Bp6MIaCjSXXRJyOxeqhnzEaF93MfFGW/O16ZvDL5TM4MJIjujz/cHypkQuuzRwWJ93BKdIt+wCRAPl9kpe2Ikkb2mFgGlxh/i40d3EHfdvoyMjIyMu43ylt/IAmGHnN5iIt7wKfbv01RAcJqFRl9lcjYQSnbQqKgC4fYOwSJt6N6trE0twZ9kN/PqNpTQeICvr4TLsDYC06U7BMjshS+v1/aT7IwQYD5LcgRQXMT2FrBfBLjZ6151jDElk9tPFfpUgk2yregusX25BJbwAFEfM+YI6vGAti4bTtizB+TjfQCrERyhKb2X8D6A9wX75P4t4neBYJeP6pdhg/gQl8MWvytzeSTjgOQBynQdh/iXKdxOrGJ/RkZGRsb9QmXihGr5+g8GGg9uTh+KoVZuNIzV+CwRucFBEyr1mVjx4irOxwM1BhirB6Q+2eNQi4eqR+aF6mELtoMzCR7V9RAFe/ZvQogNiyY8FPSUTFsLp8TeTmMui5mtw7bcaT0Yw2AA4wFRQIlkgq+1DQrNhkmoxS5Jq+u6bMAIGRECEANgXHTgWzwgBOhDH2l0oTQ4D8D5NMktBgNywAEMjo8rwATMZrPY7JGxBoJCkIBDQiAY09EGTUiBCWkUpISfGPR5AAwBfZiG2z7Ayc1yeKTxid39xBNwfHr4O0LA48ePFTvhYrF1r4tyAoz9n2MCqEuBtp/6GDR0oAYfG/R6wJExHYZHfhygsv7fEWCOj4bYmsP5A+pL4MkTfAnMlD4F+r3bobKvTyTA2P/w7PN+Agq2QW8piqMCpTBwenoKvX0AHGkGtP2YAPvTEWA7QUTAudn7/NxtOG46wWNmDtpBEkBzN7rBEvAFHp+YTB/q97qPAN4gHFqgBi8uLsC7qPCA6mg41G/+ErByPwEXDdoNxRhOx+M5jPEzQugS0ht+b1/Y3gEnYMAIAOIBE29/hIDucE8tmMsNOgK4B1RHFu4UCRlMHzv0xzcajcfdXWDs2h8TArBCkoDUJYDLmz6w7ip3BFS0ve5wTRwAn6keMA9I3QYbfSZ0DKbyt+7OXjGI1idPcfNyAyfAMlCrzaGqphYrxHocLHRJVycnfGUcbtT+jIyMjIw9x7Nn8fJSzG0TmFtO8rZT+XT3S3ub+tKJbbLd5diTVp50+zahyeHSslJ/YPrU0fuazrZO2CZ92/ZCCVXlGRiZKPJyPPRxyIFWeXLQBXJBKiq/3divEAN6ZwM200Qjm7EJBZeWm/PRWVCbYK7s7u2l4XaCz+lzgOfMfhMonXr7TWzeZb98dbgIzBT8Ub8eYYUqfZ4rVJ/MDbIDgPqTulJ/xvntWAtjIisqnwxOkGz0n077FARoY79GdA6HPE4rOy196NiMWHTZlSSApcOgXpy/fHV2joaNKu3ffsAnRcBf4K/6NcIG6tIxk3HyoXPjASqfUgXbYN5PzpL2njkR9QMjeDTVHDTCgRuxOegjoO0FvKzP/t/gmVdI24+G7NIe8JX6Wv3dDyldMA+4YB5wwTygtd+dwRqaTqrLb1l73zTSN52CNpnHuQOYPsDblybgxfkXh/oVtr+N1DEBJdhRJyd/Bd/q1z+cbNrD17iVKyajcnv9arhOkRPgsruuD6DmNPwpDNrLw2CoTgHni4yALr0L29+tiKAEIPn868ejx//8rpWP3OEOl5On9OwpcQm0MhafP/ey8f1uvDNIgGLQG8z4YO99ENgg95etwv4uYJYY8fUGHYH6j6fscHFZMftlAl9i+9XL73X3N/n+ZStOzfVfRvYXhrbdKOpEgVQTg/wsDuDD3kwOfQNMTJ5y+/ltUDWLunyxnRF46IqlBzGMY4X7inggREFioIyMjIyMHWCIB6ZNKAcXseo3vLTQTkVE7348dlwJJSz0+wLfmi8BhZqfw3D4ww/wHVLnEd5/fgYvXsDZ3MlsvYUbbnDjDZ3MN3TJG4+bxjAaDl8TBri9qxEw1ccao2wTNAMLHo2f+sjrXwb/9qHoYqgPMBXJTVfOpmrZH23y6uvo0LHSyY6fHGwKfHJlAuMFvObjDYrIqxBgQi20h7Hd/nYVLmno+eaNUm/eeH2GCuopntnhBJAlI2AHo9CCh1I1QxUdAbqqGY9BBLwyc3W4wYVhvY8A4BoIc1l5M7vnPWphZW9/Ses3n37y9a0uGqFwFQZsQQbd386DogpgEk+dzynsAZMJXq8+ns9NeukJ0PYrNATGGefJQlhkLo7DTXr+y3bNiOsDvrXTz/C2q1DXZH84iRNwrP88Nj+u2DjYEE6RBxD9Knj16ujVHC67A7422o02RwD3gB+t7EblWvu9geOFxSnd3ROmT+nJyQkhoPlsxVONc/3TEdBos+jtA+ZzcwHgTvD1cDjaYCcItA8w9i88A8b+mqSjc6Pvqd998QguEQPmQMeo23ODN86+p0/bn1buBkT6+oBhNZ/PYY4ZAHYb3PRd4LkZmPX68NRtMZn4ASvdA+qf0jMA5MP9eeg28Nug9QiLnj5A33U1MAES6xHAUNpz/9zFAYE1gqQDMT3G6xI9pwdw/aIgKoHCS1YGlRnSq9yCjdXjgN3j+N27YyROHxmuNAeNKPpYuXIyIyMjYy0M8eros59MF/PT2c602T7eA7zvhJ9dr/vzDjXaLp4Yc5+0wllzxzHv3gdmMMM7/CcQzKgVBqYTmFn+Z+mKm8J7k0A5F/jgCfjQ1WBhQyiOqD0lYuqBb+AyzMw9Ha2G3m6c8qQx+AlqnIceQp+Sb6i9UyQWbhr54+AjnZ0VzW2TAN0DmBT6PWmc6jDBE2PK2u+nF43dyP7Q0t1pOcX2fdRvH0mF2Q4JqN35rnHjVIeaXfIAVyUuw/aHCCiJy9iF5l1621zweI8KZrPZ9iJdb7DXJ3US0OSrtZ10imt7wHY7QesAzUMz1oZ3noB3qFJ/H18j97FYuw8QDN4oeKf30osvcSW2ExLo+VcbuAuo/sUIm8fMG9xocO3Ea19J9gFYivnHJ2KnyfovZlgW3v6ySx32abQiIyMjIyPjhlFDTLxpwIgFMnTp6A3g4IDKNY+stkwAMAoIAbasxBXqUWneSAWTMjt50lTqT29rFjvXohjsDNm2YPXDFlICmrJOZ3t6tHm8AiEAl0sCeLIIorIRt+cFbew/QRsoAXb4o1XSfoywzm0FTMAoYBNvLyFu8v8HpLBtD1iKgC17wHb7AI6d9wFbvguAIGTHd4E9wG7jgIyMjIyM+434c2R3HeV/Ffx6jtZu6ijl8h59T655jhR+rdHzDOP6beABCheb8O8/WFXeOyzgf5oAhVYnKxP7CwaAf1afJu8bSrhS6tdaXeGnrRenOqOlz9d6QwYnA/3TLd+GE7qe3chA5YF5DfY0vK3adfOX/gyNp2BW25MHdxAB9qvRiiP3/XpQQFGYDU4+Mi///XumXG8pjvaUAOsBGlf4jJt+YYEzeEzAdw06F19R3juM7D1wita86GR0CKfDHgLuXCc4Bri6vMLdfjMc4VNSUNsdodo2xu/1+Xl/K5+az8jIyMhYG/z5gJTMF1GtKq/a3rpyCvz5gJTMl9GtKq/a3rpyCmfQ4WwZmS+kXFVetb115ST48wEf/AGcfG1iw+tWbpbS2vJ3nQxcVr3lH3z5h972FUTLzYpOVk7l5hD+eYcYwDcAnewOotrZ4OtrPDucqi/LRX0/RR4qx7Nn4U8g+qjffvuN6Gf+nC85vwauHjaYyubqvWYKY4VEfSUMitdnBCT1Ue63R5439m+OgCn6DroAAaHPVQxKth/wkJgHmG8bmQMsT0D6EjDfvhVRKO3ywOQUgRA7nmL1uawZmHf1k+DPBwQ6NdcJ+k6Md1LA5f5ONdhJ8vZ5J0vLHT99srkGOjmJbd/G1r2Nriqnse1AZt1AalU5jW2HsuuG0qvKGRkZGRkZGRG0gcONyXsP9v8D0/IdJADiBNiXl3327WRGgOL/9HC/0XwlIURkRhC4tz6Z/fu7fUf2gHvfB9z3u0BGRkZGRkbGplHcnkgguQoSqtUXuhbs/wPtMwqV0HUJAvj5vk32b8IDuL23yn7qAXZ5u32hbRX7d3o82Df1FZXvbh9QOfhyxldr/+3xgXU9oKmvsHyr7F/XA269/eveBXrsv7N9QALe/tvjA0kPWAXGbvebkbHn+D/J5nMcHzx1UAAAAABJRU5ErkJggg==) !important}.admin-color-blue .ui-datepicker-header{background-color:#096484 !important;color:white !important}.admin-color-blue .ui-datepicker td .ui-state-active{background-color:#509dba !important;color:white !important}.admin-color-blue .ui-datepicker td .ui-state-hover{color:#509dba !important}.admin-color-blue .ui-datepicker td .ui-state-highlight{background:#4796b3 !important;border:1px solid #096484 !important;color:white !important}.admin-color-blue .redux-container-switch .cb-disable,.admin-color-blue .redux-container-switch .cb-enable,.admin-color-blue .ui-state-default,.admin-color-blue .ui-widget-content .ui-state-default,.admin-color-blue .ui-widget-header .ui-state-default{background-color:#f5f5f5 !important;background-image:-khtml-gradient(linear, left top, left bottom, from(#f8f8f8), to(#f5f5f5)) !important;background-image:-moz-linear-gradient(top, #f8f8f8, #f5f5f5) !important;background-image:-ms-linear-gradient(top, #f8f8f8, #f5f5f5) !important;background-image:-webkit-gradient(linear, left top, left bottom, color-stop(0%, #f8f8f8), color-stop(100%, #f5f5f5)) !important;background-image:-webkit-linear-gradient(top, #f8f8f8, #f5f5f5) !important;background-image:-o-linear-gradient(top, #f8f8f8, #f5f5f5) !important;background-image:-linear-gradient(top, #f8f8f8, #f5f5f5) !important;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#f8f8f8', endColorstr='#f5f5f5', GradientType=0) !important;border-color:#ccc !important}.admin-color-blue .ui-datepicker td .ui-state-active{color:black !important;font-weight:700 !important;background:white !important}.admin-color-blue .redux-container-switch .cb-disable.selected{background-color:#646464 !important;background-image:-khtml-gradient(linear, left top, left bottom, from(#929292), to(#646464)) !important;background-image:-moz-linear-gradient(top, #929292, #646464) !important;background-image:-ms-linear-gradient(top, #929292, #646464) !important;background-image:-webkit-gradient(linear, left top, left bottom, color-stop(0%, #929292), color-stop(100%, #646464)) !important;background-image:-webkit-linear-gradient(top, #929292, #646464) !important;background-image:-o-linear-gradient(top, #929292, #646464) !important;background-image:-linear-gradient(top, #929292, #646464) !important;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#929292', endColorstr='#646464', GradientType=0) !important;border-color:#767676 !important}.admin-color-blue .redux-container-switch .cb-enable.selected,.admin-color-blue .redux-field-container .ui-buttonset .ui-state-active{background-color:#4796b3 !important;background-image:-khtml-gradient(linear, left top, left bottom, from(#5ea5bf), to(#4796b3)) !important;background-image:-moz-linear-gradient(top, #5ea5bf, #4796b3) !important;background-image:-ms-linear-gradient(top, #5ea5bf, #4796b3) !important;background-image:-webkit-gradient(linear, left top, left bottom, color-stop(0%, #5ea5bf), color-stop(100%, #4796b3)) !important;background-image:-webkit-linear-gradient(top, #5ea5bf, #4796b3) !important;background-image:-o-linear-gradient(top, #5ea5bf, #4796b3) !important;background-image:-linear-gradient(top, #5ea5bf, #4796b3) !important;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#5ea5bf', endColorstr='#4796b3', GradientType=0) !important;border-color:#31687c !important;border-color:#39778e !important;-webkit-box-shadow:inset 0 1px 0 #7cb6cb,0 1px 0 rgba(0,0,0,0.15) !important;box-shadow:inset 0 1px 0 #7cb6cb,0 1px 0 rgba(0,0,0,0.15) !important}.admin-color-blue #redux-header{background:#096484;border-color:#4796b3}.admin-color-blue #redux-header .display_header span{color:#e2ecf1}.admin-color-blue .redux-sidebar .redux-group-menu li.active.hasSubSections a{position:relative}.admin-color-blue .redux-sidebar .redux-group-menu li.active.hasSubSections a:after{right:0;border:solid 8px transparent;content:"\0020";height:0;width:0;position:absolute;pointer-events:none;border-right-color:#fff;top:50%;margin-top:-8px}.admin-color-blue .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li a:after{border:0 none !important;content:"\0020" !important}.admin-color-blue .redux-sidebar .redux-group-menu li.hasSubSections .redux-menu-error{display:none;margin-right:5px}.admin-color-blue .redux-sidebar .redux-group-menu li.hasSubSections a.hasError .extraIconSubsections{background-color:#b94a48;color:#f2dede}.admin-color-blue .redux-sidebar .redux-group-menu li.hasSubSections a .extraIconSubsections{border-radius:10px;-moz-border-radius:10px;-webkit-border-radius:10px;border:0 solid transparent;float:right;font-size:9px;height:9px;line-height:9px;margin-right:5px;padding:6px 7px 4px 7px;width:5px}.admin-color-blue .redux-sidebar .redux-group-menu li.active a .extraIconSubsections,.admin-color-blue .redux-sidebar .redux-group-menu li.activeChild a .extraIconSubsections{display:none}.admin-color-blue .redux-sidebar .redux-group-menu li.active.hasSubSections .redux-menu-error,.admin-color-blue .redux-sidebar .redux-group-menu li.activeChild.hasSubSections .redux-menu-error{display:block}.admin-color-blue .redux-sidebar .redux-group-menu li.active.hasSubSections .subsection .redux-menu-error,.admin-color-blue .redux-sidebar .redux-group-menu li.activeChild.hasSubSections .subsection .redux-menu-error{margin-right:2px}.admin-color-blue .redux-sidebar .redux-group-menu li.active,.admin-color-blue .redux-sidebar .redux-group-menu li.activeChild{border-left:0 none}.admin-color-blue .redux-sidebar .redux-group-menu li.active a,.admin-color-blue .redux-sidebar .redux-group-menu li.activeChild a{color:#096484}.admin-color-blue .redux-sidebar .redux-group-menu li.active.hasSubSections .active a:after,.admin-color-blue .redux-sidebar .redux-group-menu li.activeChild.hasSubSections .active a:after{right:0;border:solid 8px transparent;content:"\0020";height:0;width:0;position:absolute;pointer-events:none;border-right-color:#fff;top:50%;margin-top:-8px}.admin-color-blue .redux-sidebar .redux-group-menu li.active.hasSubSections a,.admin-color-blue .redux-sidebar .redux-group-menu li.activeChild.hasSubSections a{-webkit-transition:all 0.2s;-moz-transition:all 0.2s;transition:all 0.2s;color:#fff;width:auto;border-bottom:0}.admin-color-blue .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li,.admin-color-blue .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li{border-top:0 none !important}.admin-color-blue .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li.active a:hover,.admin-color-blue .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li.active a:hover{color:#fff}.admin-color-blue .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li a,.admin-color-blue .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li a{width:auto;border-top:0 !important;padding:7px;color:#fff;padding-left:15px;-webkit-transition:all 0.2;-moz-transition:all 0.2;-ms-transition:all 0.2;-o-transition:all 0.2;transition:all 0.2}.admin-color-blue .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li a:hover,.admin-color-blue .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li a:hover{color:#db9825;background:#064054}.admin-color-blue .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li a span.group_title,.admin-color-blue .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li a span.group_title{padding-left:5px !important}.admin-color-blue .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li.hasIcon a,.admin-color-blue .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li.hasIcon a{padding-left:14px}.admin-color-blue .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li.hasIcon a span.group_title,.admin-color-blue .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li.hasIcon a span.group_title{padding-left:30px !important}.admin-color-blue .redux-sidebar .redux-group-menu li.active.hasSubSections a{background:#4796b3}.admin-color-blue .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li a{background:#096484}.admin-color-blue .redux-sidebar .redux-group-menu li.activeChild.hasSubSections a{background:#e2ecf1;text-shadow:1px 1px #7ba8bf}.admin-color-blue .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li a{background:#096484;text-shadow:none}.admin-color-blue .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li.active a{background:#4796b3;text-shadow:1px 1px #2a596a}.admin-color-blue .redux-container-image_select .redux-image-select-selected img{border-color:#4796b3}.admin-color-blue #redux-footer #redux-share a{color:#4796b3}.admin-color-blue #redux-footer #redux-share a:hover{color:#2a596a}.admin-color-blue .select2-results .select2-highlighted{background:#4796b3}.admin-color-blue .select2-drop-active,.admin-color-blue .select2-container-multi.select2-container-active .select2-choices,.admin-color-blue .select2-drop.select2-drop-above.select2-drop-active,.admin-color-blue .select2-container-active .select2-choice,.admin-color-blue .select2-container-active .select2-choices,.admin-color-blue .select2-dropdown-open.select2-drop-above .select2-choice,.admin-color-blue .select2-dropdown-open.select2-drop-above .select2-choices{border-color:#4796b3}.admin-color-blue .select2-dropdown-open.select2-drop-above .select2-choice,.admin-color-blue .select2-dropdown-open.select2-drop-above .select2-choices{border-top:inherit}.admin-color-blue .noUi-connect{background-color:#509dba !important;background-image:-khtml-gradient(linear, left top, left bottom, from(#69abc4), to(#509dba)) !important;background-image:-moz-linear-gradient(top, #69abc4, #509dba) !important;background-image:-ms-linear-gradient(top, #69abc4, #509dba) !important;background-image:-webkit-gradient(linear, left top, left bottom, color-stop(0%, #69abc4), color-stop(100%, #509dba)) !important;background-image:-webkit-linear-gradient(top, #69abc4, #509dba) !important;background-image:-o-linear-gradient(top, #69abc4, #509dba) !important;background-image:-linear-gradient(top, #69abc4, #509dba) !important;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#69abc4', endColorstr='#509dba', GradientType=0) !important}.admin-color-coffee .button.ui-datepicker-current,.admin-color-coffee button.ui-datepicker-close{background-color:#ccad93 !important}.admin-color-coffee .ui-datepicker-buttonpane button.ui-datepicker-current{background:#ba906d !important;color:white !important;border:1px solid #835d3e !important}.admin-color-coffee .ui-datepicker-header .ui-icon{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAQAAAADwCAMAAADYSUr5AAAA7VBMVEX8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vywC3+8AAAATnRSTlMAGBAyBAhQv4OZLiJUcEBmYBoSzQwgPBZCSEoeWiYwUiyFNIeBw2rJz8c4RBy9uXyrtaWNqa2zKP2fJO8KBgKPo2KVoa9s351GPm5+kWho0kj9AAAPhUlEQVR4nO1djWLbthEGyUiq5YSSLXtp7FpLOmfzkmxr126tmi2p03RJ1/Xe/3EGgARxPyAgRbIk2/hkSz4CJO4+HsE7AJSVysjI2AMUUOxahZ2iANhzBtZWr4BoIRSYAVN5u4QwDwQDRbcwfUi5KS3wFuDmFnQLa4Dtb//cqktwD5QEFFwfUs7PoCCA7y4bEJVFizcIob8KmhAplwwqVjt+9FBl3uINQniwEiryEyw9JHqGpQdEFNi+B4QQ7QOiHhysIPoAxUqxvdvvA9K42bsAv4S2fxfYOe57IJSRkZGRkZGxx7jxSHDHcRBXQMTyIjInBgHwBJ/bEx8PEANC+uhbpSSggCBAVODVabpI1S/k4WLZpTn6NpMhoX9Y40hxYERFpMcqUs4AloCtDQdID1YhnyXZ2hLjAYWiO9Dy1PDB7tPhIqLx+uMB8grZaR+Qxl2/C2RkZGRkZGRk7A7rBf7J0DR5/LUTjzUPIPSPGvQJiVJiB7kcQCiUOJrcFNtDZIf2xarQ3aGvLNxAVIFAabz90BFiBIlycTBhgWwOWCH0FLYHlPqwHaCvcIn2ZbosCevfPTRiFFcgvHukCjWwrc3GrGh1fsAof8EaUReKXkCB4/MzFNo97qLpFiKFYv/kNR5YQxQbQEofkZ2OuEOHqqT6gFTpru8CN7x/+jaZkZGRkZGRcV+x/rLUNcMMqUAscgnFocmpqkTzqymwVAPxfJ5PnIUUQOUKT04tEdWZyv3JCQSn96WS4pD97QfyW25A7NhSAbyhmVj0FEltA4vdiygBibXhoUYgykCUP7HwPTDeEqAIcHVMkZg7Zx4k0uFANs63hPQXCoRLAwdgGsr9Az7Qv7sgQGgg1aPl/BJLExBWgG4RFRLFImGmIquPC/klEGyCG0AuAXaJJC+B8FVe9NYQDEcXB8g6AQcjYJ1goJIggHWCrFR0S6kRHN5+4BzFi8NaoN35NRxUvL+JJdZr7PV4wK6fj8nIyMjIyNhr3OxdXAYq7FHZwB6bDSzSh4sF0utChqo0NAvaT1hLzXwFinmCzmeDucEQK18TTaQoFgP7bNC+RZ4OT4T6gQogDFYk+1QxQlj19QGSAWKiLYp8P0Ag1Gbz1ULfWHLg9iUnQNK5QQJcukm04blKLH2GgEJCY+HzXAZWCvHKco3Bp6MIaCjSXXRJyOxeqhnzEaF93MfFGW/O16ZvDL5TM4MJIjujz/cHypkQuuzRwWJ93BKdIt+wCRAPl9kpe2Ikkb2mFgGlxh/i40d3EHfdvoyMjIyMu43ylt/IAmGHnN5iIt7wKfbv01RAcJqFRl9lcjYQSnbQqKgC4fYOwSJt6N6trE0twZ9kN/PqNpTQeICvr4TLsDYC06U7BMjshS+v1/aT7IwQYD5LcgRQXMT2FrBfBLjZ6151jDElk9tPFfpUgk2yregusX25BJbwAFEfM+YI6vGAti4bTtizB+TjfQCrERyhKb2X8D6A9wX75P4t4neBYJeP6pdhg/gQl8MWvytzeSTjgOQBynQdh/iXKdxOrGJ/RkZGRsb9QmXihGr5+g8GGg9uTh+KoVZuNIzV+CwRucFBEyr1mVjx4irOxwM1BhirB6Q+2eNQi4eqR+aF6mELtoMzCR7V9RAFe/ZvQogNiyY8FPSUTFsLp8TeTmMui5mtw7bcaT0Yw2AA4wFRQIlkgq+1DQrNhkmoxS5Jq+u6bMAIGRECEANgXHTgWzwgBOhDH2l0oTQ4D8D5NMktBgNywAEMjo8rwATMZrPY7JGxBoJCkIBDQiAY09EGTUiBCWkUpISfGPR5AAwBfZiG2z7Ayc1yeKTxid39xBNwfHr4O0LA48ePFTvhYrF1r4tyAoz9n2MCqEuBtp/6GDR0oAYfG/R6wJExHYZHfhygsv7fEWCOj4bYmsP5A+pL4MkTfAnMlD4F+r3bobKvTyTA2P/w7PN+Agq2QW8piqMCpTBwenoKvX0AHGkGtP2YAPvTEWA7QUTAudn7/NxtOG46wWNmDtpBEkBzN7rBEvAFHp+YTB/q97qPAN4gHFqgBi8uLsC7qPCA6mg41G/+ErByPwEXDdoNxRhOx+M5jPEzQugS0ht+b1/Y3gEnYMAIAOIBE29/hIDucE8tmMsNOgK4B1RHFu4UCRlMHzv0xzcajcfdXWDs2h8TArBCkoDUJYDLmz6w7ip3BFS0ve5wTRwAn6keMA9I3QYbfSZ0DKbyt+7OXjGI1idPcfNyAyfAMlCrzaGqphYrxHocLHRJVycnfGUcbtT+jIyMjIw9x7Nn8fJSzG0TmFtO8rZT+XT3S3ub+tKJbbLd5diTVp50+zahyeHSslJ/YPrU0fuazrZO2CZ92/ZCCVXlGRiZKPJyPPRxyIFWeXLQBXJBKiq/3divEAN6ZwM200Qjm7EJBZeWm/PRWVCbYK7s7u2l4XaCz+lzgOfMfhMonXr7TWzeZb98dbgIzBT8Ub8eYYUqfZ4rVJ/MDbIDgPqTulJ/xvntWAtjIisqnwxOkGz0n077FARoY79GdA6HPE4rOy196NiMWHTZlSSApcOgXpy/fHV2joaNKu3ffsAnRcBf4K/6NcIG6tIxk3HyoXPjASqfUgXbYN5PzpL2njkR9QMjeDTVHDTCgRuxOegjoO0FvKzP/t/gmVdI24+G7NIe8JX6Wv3dDyldMA+4YB5wwTygtd+dwRqaTqrLb1l73zTSN52CNpnHuQOYPsDblybgxfkXh/oVtr+N1DEBJdhRJyd/Bd/q1z+cbNrD17iVKyajcnv9arhOkRPgsruuD6DmNPwpDNrLw2CoTgHni4yALr0L29+tiKAEIPn868ejx//8rpWP3OEOl5On9OwpcQm0MhafP/ey8f1uvDNIgGLQG8z4YO99ENgg95etwv4uYJYY8fUGHYH6j6fscHFZMftlAl9i+9XL73X3N/n+ZStOzfVfRvYXhrbdKOpEgVQTg/wsDuDD3kwOfQNMTJ5y+/ltUDWLunyxnRF46IqlBzGMY4X7inggREFioIyMjIyMHWCIB6ZNKAcXseo3vLTQTkVE7348dlwJJSz0+wLfmi8BhZqfw3D4ww/wHVLnEd5/fgYvXsDZ3MlsvYUbbnDjDZ3MN3TJG4+bxjAaDl8TBri9qxEw1ccao2wTNAMLHo2f+sjrXwb/9qHoYqgPMBXJTVfOpmrZH23y6uvo0LHSyY6fHGwKfHJlAuMFvObjDYrIqxBgQi20h7Hd/nYVLmno+eaNUm/eeH2GCuopntnhBJAlI2AHo9CCh1I1QxUdAbqqGY9BBLwyc3W4wYVhvY8A4BoIc1l5M7vnPWphZW9/Ses3n37y9a0uGqFwFQZsQQbd386DogpgEk+dzynsAZMJXq8+ns9NeukJ0PYrNATGGefJQlhkLo7DTXr+y3bNiOsDvrXTz/C2q1DXZH84iRNwrP88Nj+u2DjYEE6RBxD9Knj16ujVHC67A7422o02RwD3gB+t7EblWvu9geOFxSnd3ROmT+nJyQkhoPlsxVONc/3TEdBos+jtA+ZzcwHgTvD1cDjaYCcItA8w9i88A8b+mqSjc6Pvqd998QguEQPmQMeo23ODN86+p0/bn1buBkT6+oBhNZ/PYY4ZAHYb3PRd4LkZmPX68NRtMZn4ASvdA+qf0jMA5MP9eeg28Nug9QiLnj5A33U1MAES6xHAUNpz/9zFAYE1gqQDMT3G6xI9pwdw/aIgKoHCS1YGlRnSq9yCjdXjgN3j+N27YyROHxmuNAeNKPpYuXIyIyMjYy0M8eros59MF/PT2c602T7eA7zvhJ9dr/vzDjXaLp4Yc5+0wllzxzHv3gdmMMM7/CcQzKgVBqYTmFn+Z+mKm8J7k0A5F/jgCfjQ1WBhQyiOqD0lYuqBb+AyzMw9Ha2G3m6c8qQx+AlqnIceQp+Sb6i9UyQWbhr54+AjnZ0VzW2TAN0DmBT6PWmc6jDBE2PK2u+nF43dyP7Q0t1pOcX2fdRvH0mF2Q4JqN35rnHjVIeaXfIAVyUuw/aHCCiJy9iF5l1621zweI8KZrPZ9iJdb7DXJ3US0OSrtZ10imt7wHY7QesAzUMz1oZ3noB3qFJ/H18j97FYuw8QDN4oeKf30osvcSW2ExLo+VcbuAuo/sUIm8fMG9xocO3Ea19J9gFYivnHJ2KnyfovZlgW3v6ySx32abQiIyMjIyPjhlFDTLxpwIgFMnTp6A3g4IDKNY+stkwAMAoIAbasxBXqUWneSAWTMjt50lTqT29rFjvXohjsDNm2YPXDFlICmrJOZ3t6tHm8AiEAl0sCeLIIorIRt+cFbew/QRsoAXb4o1XSfoywzm0FTMAoYBNvLyFu8v8HpLBtD1iKgC17wHb7AI6d9wFbvguAIGTHd4E9wG7jgIyMjIyM+434c2R3HeV/Ffx6jtZu6ijl8h59T655jhR+rdHzDOP6beABCheb8O8/WFXeOyzgf5oAhVYnKxP7CwaAf1afJu8bSrhS6tdaXeGnrRenOqOlz9d6QwYnA/3TLd+GE7qe3chA5YF5DfY0vK3adfOX/gyNp2BW25MHdxAB9qvRiiP3/XpQQFGYDU4+Mi///XumXG8pjvaUAOsBGlf4jJt+YYEzeEzAdw06F19R3juM7D1wita86GR0CKfDHgLuXCc4Bri6vMLdfjMc4VNSUNsdodo2xu/1+Xl/K5+az8jIyMhYG/z5gJTMF1GtKq/a3rpyCvz5gJTMl9GtKq/a3rpyCmfQ4WwZmS+kXFVetb115ST48wEf/AGcfG1iw+tWbpbS2vJ3nQxcVr3lH3z5h972FUTLzYpOVk7l5hD+eYcYwDcAnewOotrZ4OtrPDucqi/LRX0/RR4qx7Nn4U8g+qjffvuN6Gf+nC85vwauHjaYyubqvWYKY4VEfSUMitdnBCT1Ue63R5439m+OgCn6DroAAaHPVQxKth/wkJgHmG8bmQMsT0D6EjDfvhVRKO3ywOQUgRA7nmL1uawZmHf1k+DPBwQ6NdcJ+k6Md1LA5f5ONdhJ8vZ5J0vLHT99srkGOjmJbd/G1r2Nriqnse1AZt1AalU5jW2HsuuG0qvKGRkZGRkZGRG0gcONyXsP9v8D0/IdJADiBNiXl3327WRGgOL/9HC/0XwlIURkRhC4tz6Z/fu7fUf2gHvfB9z3u0BGRkZGRkbGplHcnkgguQoSqtUXuhbs/wPtMwqV0HUJAvj5vk32b8IDuL23yn7qAXZ5u32hbRX7d3o82Df1FZXvbh9QOfhyxldr/+3xgXU9oKmvsHyr7F/XA269/eveBXrsv7N9QALe/tvjA0kPWAXGbvebkbHn+D/J5nMcHzx1UAAAAABJRU5ErkJggg==) !important}.admin-color-coffee .ui-datepicker-header{background-color:#46403c !important;color:white !important}.admin-color-coffee .ui-datepicker td .ui-state-active{background-color:#ccad93 !important;color:white !important}.admin-color-coffee .ui-datepicker td .ui-state-hover{color:#ccad93 !important}.admin-color-coffee .ui-datepicker td .ui-state-highlight{background:#c7a589 !important;border:1px solid #46403c !important;color:white !important}.admin-color-coffee .redux-container-switch .cb-disable,.admin-color-coffee .redux-container-switch .cb-enable,.admin-color-coffee .ui-state-default,.admin-color-coffee .ui-widget-content .ui-state-default,.admin-color-coffee .ui-widget-header .ui-state-default{background-color:#f5f5f5 !important;background-image:-khtml-gradient(linear, left top, left bottom, from(#f8f8f8), to(#f5f5f5)) !important;background-image:-moz-linear-gradient(top, #f8f8f8, #f5f5f5) !important;background-image:-ms-linear-gradient(top, #f8f8f8, #f5f5f5) !important;background-image:-webkit-gradient(linear, left top, left bottom, color-stop(0%, #f8f8f8), color-stop(100%, #f5f5f5)) !important;background-image:-webkit-linear-gradient(top, #f8f8f8, #f5f5f5) !important;background-image:-o-linear-gradient(top, #f8f8f8, #f5f5f5) !important;background-image:-linear-gradient(top, #f8f8f8, #f5f5f5) !important;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#f8f8f8', endColorstr='#f5f5f5', GradientType=0) !important;border-color:#ccc !important}.admin-color-coffee .ui-datepicker td .ui-state-active{color:black !important;font-weight:700 !important;background:white !important}.admin-color-coffee .redux-container-switch .cb-disable.selected{background-color:#646464 !important;background-image:-khtml-gradient(linear, left top, left bottom, from(#929292), to(#646464)) !important;background-image:-moz-linear-gradient(top, #929292, #646464) !important;background-image:-ms-linear-gradient(top, #929292, #646464) !important;background-image:-webkit-gradient(linear, left top, left bottom, color-stop(0%, #929292), color-stop(100%, #646464)) !important;background-image:-webkit-linear-gradient(top, #929292, #646464) !important;background-image:-o-linear-gradient(top, #929292, #646464) !important;background-image:-linear-gradient(top, #929292, #646464) !important;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#929292', endColorstr='#646464', GradientType=0) !important;border-color:#767676 !important}.admin-color-coffee .redux-container-switch .cb-enable.selected,.admin-color-coffee .redux-field-container .ui-buttonset .ui-state-active{background-color:#c7a589 !important;background-image:-khtml-gradient(linear, left top, left bottom, from(#d2b7a1), to(#c7a589)) !important;background-image:-moz-linear-gradient(top, #d2b7a1, #c7a589) !important;background-image:-ms-linear-gradient(top, #d2b7a1, #c7a589) !important;background-image:-webkit-gradient(linear, left top, left bottom, color-stop(0%, #d2b7a1), color-stop(100%, #c7a589)) !important;background-image:-webkit-linear-gradient(top, #d2b7a1, #c7a589) !important;background-image:-o-linear-gradient(top, #d2b7a1, #c7a589) !important;background-image:-linear-gradient(top, #d2b7a1, #c7a589) !important;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#d2b7a1', endColorstr='#c7a589', GradientType=0) !important;border-color:#ae7d55 !important;border-color:#b78b66 !important;-webkit-box-shadow:inset 0 1px 0 #e0cdbd,0 1px 0 rgba(0,0,0,0.15) !important;box-shadow:inset 0 1px 0 #e0cdbd,0 1px 0 rgba(0,0,0,0.15) !important}.admin-color-coffee #redux-header{background:#46403c;border-color:#c7a589}.admin-color-coffee #redux-header .display_header span{color:#cdcbc9}.admin-color-coffee .redux-sidebar .redux-group-menu li.active.hasSubSections a{position:relative}.admin-color-coffee .redux-sidebar .redux-group-menu li.active.hasSubSections a:after{right:0;border:solid 8px transparent;content:"\0020";height:0;width:0;position:absolute;pointer-events:none;border-right-color:#fff;top:50%;margin-top:-8px}.admin-color-coffee .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li a:after{border:0 none !important;content:"\0020" !important}.admin-color-coffee .redux-sidebar .redux-group-menu li.hasSubSections .redux-menu-error{display:none;margin-right:5px}.admin-color-coffee .redux-sidebar .redux-group-menu li.hasSubSections a.hasError .extraIconSubsections{background-color:#b94a48;color:#f2dede}.admin-color-coffee .redux-sidebar .redux-group-menu li.hasSubSections a .extraIconSubsections{border-radius:10px;-moz-border-radius:10px;-webkit-border-radius:10px;border:0 solid transparent;float:right;font-size:9px;height:9px;line-height:9px;margin-right:5px;padding:6px 7px 4px 7px;width:5px}.admin-color-coffee .redux-sidebar .redux-group-menu li.active a .extraIconSubsections,.admin-color-coffee .redux-sidebar .redux-group-menu li.activeChild a .extraIconSubsections{display:none}.admin-color-coffee .redux-sidebar .redux-group-menu li.active.hasSubSections .redux-menu-error,.admin-color-coffee .redux-sidebar .redux-group-menu li.activeChild.hasSubSections .redux-menu-error{display:block}.admin-color-coffee .redux-sidebar .redux-group-menu li.active.hasSubSections .subsection .redux-menu-error,.admin-color-coffee .redux-sidebar .redux-group-menu li.activeChild.hasSubSections .subsection .redux-menu-error{margin-right:2px}.admin-color-coffee .redux-sidebar .redux-group-menu li.active,.admin-color-coffee .redux-sidebar .redux-group-menu li.activeChild{border-left:0 none}.admin-color-coffee .redux-sidebar .redux-group-menu li.active a,.admin-color-coffee .redux-sidebar .redux-group-menu li.activeChild a{color:#46403c}.admin-color-coffee .redux-sidebar .redux-group-menu li.active.hasSubSections .active a:after,.admin-color-coffee .redux-sidebar .redux-group-menu li.activeChild.hasSubSections .active a:after{right:0;border:solid 8px transparent;content:"\0020";height:0;width:0;position:absolute;pointer-events:none;border-right-color:#fff;top:50%;margin-top:-8px}.admin-color-coffee .redux-sidebar .redux-group-menu li.active.hasSubSections a,.admin-color-coffee .redux-sidebar .redux-group-menu li.activeChild.hasSubSections a{-webkit-transition:all 0.2s;-moz-transition:all 0.2s;transition:all 0.2s;color:#fff;width:auto;border-bottom:0}.admin-color-coffee .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li,.admin-color-coffee .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li{border-top:0 none !important}.admin-color-coffee .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li.active a:hover,.admin-color-coffee .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li.active a:hover{color:#fff}.admin-color-coffee .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li a,.admin-color-coffee .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li a{width:auto;border-top:0 !important;padding:7px;color:#fff;padding-left:15px;-webkit-transition:all 0.2;-moz-transition:all 0.2;-ms-transition:all 0.2;-o-transition:all 0.2;transition:all 0.2}.admin-color-coffee .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li a:hover,.admin-color-coffee .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li a:hover{color:#ba906d;background:#2b2724}.admin-color-coffee .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li a span.group_title,.admin-color-coffee .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li a span.group_title{padding-left:5px !important}.admin-color-coffee .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li.hasIcon a,.admin-color-coffee .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li.hasIcon a{padding-left:14px}.admin-color-coffee .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li.hasIcon a span.group_title,.admin-color-coffee .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li.hasIcon a span.group_title{padding-left:30px !important}.admin-color-coffee .redux-sidebar .redux-group-menu li.active.hasSubSections a{background:#c7a589}.admin-color-coffee .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li a{background:#46403c}.admin-color-coffee .redux-sidebar .redux-group-menu li.activeChild.hasSubSections a{background:#cdcbc9;text-shadow:1px 1px #837e7a}.admin-color-coffee .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li a{background:#46403c;text-shadow:none}.admin-color-coffee .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li.active a{background:#c7a589;text-shadow:1px 1px #9f714b}.admin-color-coffee .redux-container-image_select .redux-image-select-selected img{border-color:#c7a589}.admin-color-coffee #redux-footer #redux-share a{color:#c7a589}.admin-color-coffee #redux-footer #redux-share a:hover{color:#9f714b}.admin-color-coffee .select2-results .select2-highlighted{background:#c7a589}.admin-color-coffee .select2-drop-active,.admin-color-coffee .select2-container-multi.select2-container-active .select2-choices,.admin-color-coffee .select2-drop.select2-drop-above.select2-drop-active,.admin-color-coffee .select2-container-active .select2-choice,.admin-color-coffee .select2-container-active .select2-choices,.admin-color-coffee .select2-dropdown-open.select2-drop-above .select2-choice,.admin-color-coffee .select2-dropdown-open.select2-drop-above .select2-choices{border-color:#c7a589}.admin-color-coffee .select2-dropdown-open.select2-drop-above .select2-choice,.admin-color-coffee .select2-dropdown-open.select2-drop-above .select2-choices{border-top:inherit}.admin-color-coffee .noUi-connect{background-color:#ccad93 !important;background-image:-khtml-gradient(linear, left top, left bottom, from(#d7bfac), to(#ccad93)) !important;background-image:-moz-linear-gradient(top, #d7bfac, #ccad93) !important;background-image:-ms-linear-gradient(top, #d7bfac, #ccad93) !important;background-image:-webkit-gradient(linear, left top, left bottom, color-stop(0%, #d7bfac), color-stop(100%, #ccad93)) !important;background-image:-webkit-linear-gradient(top, #d7bfac, #ccad93) !important;background-image:-o-linear-gradient(top, #d7bfac, #ccad93) !important;background-image:-linear-gradient(top, #d7bfac, #ccad93) !important;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#d7bfac', endColorstr='#ccad93', GradientType=0) !important}.admin-color-ectoplasm .button.ui-datepicker-current,.admin-color-ectoplasm button.ui-datepicker-close{background-color:#a9bd4f !important}.admin-color-ectoplasm .ui-datepicker-buttonpane button.ui-datepicker-current{background:#89993a !important;color:white !important;border:1px solid #474f1e !important}.admin-color-ectoplasm .ui-datepicker-header .ui-icon{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAQAAAADwCAMAAADYSUr5AAAA7VBMVEX8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vywC3+8AAAATnRSTlMAGBAyBAhQv4OZLiJUcEBmYBoSzQwgPBZCSEoeWiYwUiyFNIeBw2rJz8c4RBy9uXyrtaWNqa2zKP2fJO8KBgKPo2KVoa9s351GPm5+kWho0kj9AAAPhUlEQVR4nO1djWLbthEGyUiq5YSSLXtp7FpLOmfzkmxr126tmi2p03RJ1/Xe/3EGgARxPyAgRbIk2/hkSz4CJO4+HsE7AJSVysjI2AMUUOxahZ2iANhzBtZWr4BoIRSYAVN5u4QwDwQDRbcwfUi5KS3wFuDmFnQLa4Dtb//cqktwD5QEFFwfUs7PoCCA7y4bEJVFizcIob8KmhAplwwqVjt+9FBl3uINQniwEiryEyw9JHqGpQdEFNi+B4QQ7QOiHhysIPoAxUqxvdvvA9K42bsAv4S2fxfYOe57IJSRkZGRkZGxx7jxSHDHcRBXQMTyIjInBgHwBJ/bEx8PEANC+uhbpSSggCBAVODVabpI1S/k4WLZpTn6NpMhoX9Y40hxYERFpMcqUs4AloCtDQdID1YhnyXZ2hLjAYWiO9Dy1PDB7tPhIqLx+uMB8grZaR+Qxl2/C2RkZGRkZGRk7A7rBf7J0DR5/LUTjzUPIPSPGvQJiVJiB7kcQCiUOJrcFNtDZIf2xarQ3aGvLNxAVIFAabz90BFiBIlycTBhgWwOWCH0FLYHlPqwHaCvcIn2ZbosCevfPTRiFFcgvHukCjWwrc3GrGh1fsAof8EaUReKXkCB4/MzFNo97qLpFiKFYv/kNR5YQxQbQEofkZ2OuEOHqqT6gFTpru8CN7x/+jaZkZGRkZGRcV+x/rLUNcMMqUAscgnFocmpqkTzqymwVAPxfJ5PnIUUQOUKT04tEdWZyv3JCQSn96WS4pD97QfyW25A7NhSAbyhmVj0FEltA4vdiygBibXhoUYgykCUP7HwPTDeEqAIcHVMkZg7Zx4k0uFANs63hPQXCoRLAwdgGsr9Az7Qv7sgQGgg1aPl/BJLExBWgG4RFRLFImGmIquPC/klEGyCG0AuAXaJJC+B8FVe9NYQDEcXB8g6AQcjYJ1goJIggHWCrFR0S6kRHN5+4BzFi8NaoN35NRxUvL+JJdZr7PV4wK6fj8nIyMjIyNhr3OxdXAYq7FHZwB6bDSzSh4sF0utChqo0NAvaT1hLzXwFinmCzmeDucEQK18TTaQoFgP7bNC+RZ4OT4T6gQogDFYk+1QxQlj19QGSAWKiLYp8P0Ag1Gbz1ULfWHLg9iUnQNK5QQJcukm04blKLH2GgEJCY+HzXAZWCvHKco3Bp6MIaCjSXXRJyOxeqhnzEaF93MfFGW/O16ZvDL5TM4MJIjujz/cHypkQuuzRwWJ93BKdIt+wCRAPl9kpe2Ikkb2mFgGlxh/i40d3EHfdvoyMjIyMu43ylt/IAmGHnN5iIt7wKfbv01RAcJqFRl9lcjYQSnbQqKgC4fYOwSJt6N6trE0twZ9kN/PqNpTQeICvr4TLsDYC06U7BMjshS+v1/aT7IwQYD5LcgRQXMT2FrBfBLjZ6151jDElk9tPFfpUgk2yregusX25BJbwAFEfM+YI6vGAti4bTtizB+TjfQCrERyhKb2X8D6A9wX75P4t4neBYJeP6pdhg/gQl8MWvytzeSTjgOQBynQdh/iXKdxOrGJ/RkZGRsb9QmXihGr5+g8GGg9uTh+KoVZuNIzV+CwRucFBEyr1mVjx4irOxwM1BhirB6Q+2eNQi4eqR+aF6mELtoMzCR7V9RAFe/ZvQogNiyY8FPSUTFsLp8TeTmMui5mtw7bcaT0Yw2AA4wFRQIlkgq+1DQrNhkmoxS5Jq+u6bMAIGRECEANgXHTgWzwgBOhDH2l0oTQ4D8D5NMktBgNywAEMjo8rwATMZrPY7JGxBoJCkIBDQiAY09EGTUiBCWkUpISfGPR5AAwBfZiG2z7Ayc1yeKTxid39xBNwfHr4O0LA48ePFTvhYrF1r4tyAoz9n2MCqEuBtp/6GDR0oAYfG/R6wJExHYZHfhygsv7fEWCOj4bYmsP5A+pL4MkTfAnMlD4F+r3bobKvTyTA2P/w7PN+Agq2QW8piqMCpTBwenoKvX0AHGkGtP2YAPvTEWA7QUTAudn7/NxtOG46wWNmDtpBEkBzN7rBEvAFHp+YTB/q97qPAN4gHFqgBi8uLsC7qPCA6mg41G/+ErByPwEXDdoNxRhOx+M5jPEzQugS0ht+b1/Y3gEnYMAIAOIBE29/hIDucE8tmMsNOgK4B1RHFu4UCRlMHzv0xzcajcfdXWDs2h8TArBCkoDUJYDLmz6w7ip3BFS0ve5wTRwAn6keMA9I3QYbfSZ0DKbyt+7OXjGI1idPcfNyAyfAMlCrzaGqphYrxHocLHRJVycnfGUcbtT+jIyMjIw9x7Nn8fJSzG0TmFtO8rZT+XT3S3ub+tKJbbLd5diTVp50+zahyeHSslJ/YPrU0fuazrZO2CZ92/ZCCVXlGRiZKPJyPPRxyIFWeXLQBXJBKiq/3divEAN6ZwM200Qjm7EJBZeWm/PRWVCbYK7s7u2l4XaCz+lzgOfMfhMonXr7TWzeZb98dbgIzBT8Ub8eYYUqfZ4rVJ/MDbIDgPqTulJ/xvntWAtjIisqnwxOkGz0n077FARoY79GdA6HPE4rOy196NiMWHTZlSSApcOgXpy/fHV2joaNKu3ffsAnRcBf4K/6NcIG6tIxk3HyoXPjASqfUgXbYN5PzpL2njkR9QMjeDTVHDTCgRuxOegjoO0FvKzP/t/gmVdI24+G7NIe8JX6Wv3dDyldMA+4YB5wwTygtd+dwRqaTqrLb1l73zTSN52CNpnHuQOYPsDblybgxfkXh/oVtr+N1DEBJdhRJyd/Bd/q1z+cbNrD17iVKyajcnv9arhOkRPgsruuD6DmNPwpDNrLw2CoTgHni4yALr0L29+tiKAEIPn868ejx//8rpWP3OEOl5On9OwpcQm0MhafP/ey8f1uvDNIgGLQG8z4YO99ENgg95etwv4uYJYY8fUGHYH6j6fscHFZMftlAl9i+9XL73X3N/n+ZStOzfVfRvYXhrbdKOpEgVQTg/wsDuDD3kwOfQNMTJ5y+/ltUDWLunyxnRF46IqlBzGMY4X7inggREFioIyMjIyMHWCIB6ZNKAcXseo3vLTQTkVE7348dlwJJSz0+wLfmi8BhZqfw3D4ww/wHVLnEd5/fgYvXsDZ3MlsvYUbbnDjDZ3MN3TJG4+bxjAaDl8TBri9qxEw1ccao2wTNAMLHo2f+sjrXwb/9qHoYqgPMBXJTVfOpmrZH23y6uvo0LHSyY6fHGwKfHJlAuMFvObjDYrIqxBgQi20h7Hd/nYVLmno+eaNUm/eeH2GCuopntnhBJAlI2AHo9CCh1I1QxUdAbqqGY9BBLwyc3W4wYVhvY8A4BoIc1l5M7vnPWphZW9/Ses3n37y9a0uGqFwFQZsQQbd386DogpgEk+dzynsAZMJXq8+ns9NeukJ0PYrNATGGefJQlhkLo7DTXr+y3bNiOsDvrXTz/C2q1DXZH84iRNwrP88Nj+u2DjYEE6RBxD9Knj16ujVHC67A7422o02RwD3gB+t7EblWvu9geOFxSnd3ROmT+nJyQkhoPlsxVONc/3TEdBos+jtA+ZzcwHgTvD1cDjaYCcItA8w9i88A8b+mqSjc6Pvqd998QguEQPmQMeo23ODN86+p0/bn1buBkT6+oBhNZ/PYY4ZAHYb3PRd4LkZmPX68NRtMZn4ASvdA+qf0jMA5MP9eeg28Nug9QiLnj5A33U1MAES6xHAUNpz/9zFAYE1gqQDMT3G6xI9pwdw/aIgKoHCS1YGlRnSq9yCjdXjgN3j+N27YyROHxmuNAeNKPpYuXIyIyMjYy0M8eros59MF/PT2c602T7eA7zvhJ9dr/vzDjXaLp4Yc5+0wllzxzHv3gdmMMM7/CcQzKgVBqYTmFn+Z+mKm8J7k0A5F/jgCfjQ1WBhQyiOqD0lYuqBb+AyzMw9Ha2G3m6c8qQx+AlqnIceQp+Sb6i9UyQWbhr54+AjnZ0VzW2TAN0DmBT6PWmc6jDBE2PK2u+nF43dyP7Q0t1pOcX2fdRvH0mF2Q4JqN35rnHjVIeaXfIAVyUuw/aHCCiJy9iF5l1621zweI8KZrPZ9iJdb7DXJ3US0OSrtZ10imt7wHY7QesAzUMz1oZ3noB3qFJ/H18j97FYuw8QDN4oeKf30osvcSW2ExLo+VcbuAuo/sUIm8fMG9xocO3Ea19J9gFYivnHJ2KnyfovZlgW3v6ySx32abQiIyMjIyPjhlFDTLxpwIgFMnTp6A3g4IDKNY+stkwAMAoIAbasxBXqUWneSAWTMjt50lTqT29rFjvXohjsDNm2YPXDFlICmrJOZ3t6tHm8AiEAl0sCeLIIorIRt+cFbew/QRsoAXb4o1XSfoywzm0FTMAoYBNvLyFu8v8HpLBtD1iKgC17wHb7AI6d9wFbvguAIGTHd4E9wG7jgIyMjIyM+434c2R3HeV/Ffx6jtZu6ijl8h59T655jhR+rdHzDOP6beABCheb8O8/WFXeOyzgf5oAhVYnKxP7CwaAf1afJu8bSrhS6tdaXeGnrRenOqOlz9d6QwYnA/3TLd+GE7qe3chA5YF5DfY0vK3adfOX/gyNp2BW25MHdxAB9qvRiiP3/XpQQFGYDU4+Mi///XumXG8pjvaUAOsBGlf4jJt+YYEzeEzAdw06F19R3juM7D1wita86GR0CKfDHgLuXCc4Bri6vMLdfjMc4VNSUNsdodo2xu/1+Xl/K5+az8jIyMhYG/z5gJTMF1GtKq/a3rpyCvz5gJTMl9GtKq/a3rpyCmfQ4WwZmS+kXFVetb115ST48wEf/AGcfG1iw+tWbpbS2vJ3nQxcVr3lH3z5h972FUTLzYpOVk7l5hD+eYcYwDcAnewOotrZ4OtrPDucqi/LRX0/RR4qx7Nn4U8g+qjffvuN6Gf+nC85vwauHjaYyubqvWYKY4VEfSUMitdnBCT1Ue63R5439m+OgCn6DroAAaHPVQxKth/wkJgHmG8bmQMsT0D6EjDfvhVRKO3ywOQUgRA7nmL1uawZmHf1k+DPBwQ6NdcJ+k6Md1LA5f5ONdhJ8vZ5J0vLHT99srkGOjmJbd/G1r2Nriqnse1AZt1AalU5jW2HsuuG0qvKGRkZGRkZGRG0gcONyXsP9v8D0/IdJADiBNiXl3327WRGgOL/9HC/0XwlIURkRhC4tz6Z/fu7fUf2gHvfB9z3u0BGRkZGRkbGplHcnkgguQoSqtUXuhbs/wPtMwqV0HUJAvj5vk32b8IDuL23yn7qAXZ5u32hbRX7d3o82Df1FZXvbh9QOfhyxldr/+3xgXU9oKmvsHyr7F/XA269/eveBXrsv7N9QALe/tvjA0kPWAXGbvebkbHn+D/J5nMcHzx1UAAAAABJRU5ErkJggg==) !important}.admin-color-ectoplasm .ui-datepicker-header{background-color:#413256 !important;color:white !important}.admin-color-ectoplasm .ui-datepicker td .ui-state-active{background-color:#a9bd4f !important;color:white !important}.admin-color-ectoplasm .ui-datepicker td .ui-state-hover{color:#a9bd4f !important}.admin-color-ectoplasm .ui-datepicker td .ui-state-highlight{background:#a3b745 !important;border:1px solid #413256 !important;color:white !important}.admin-color-ectoplasm .redux-container-switch .cb-disable,.admin-color-ectoplasm .redux-container-switch .cb-enable,.admin-color-ectoplasm .ui-state-default,.admin-color-ectoplasm .ui-widget-content .ui-state-default,.admin-color-ectoplasm .ui-widget-header .ui-state-default{background-color:#f5f5f5 !important;background-image:-khtml-gradient(linear, left top, left bottom, from(#f8f8f8), to(#f5f5f5)) !important;background-image:-moz-linear-gradient(top, #f8f8f8, #f5f5f5) !important;background-image:-ms-linear-gradient(top, #f8f8f8, #f5f5f5) !important;background-image:-webkit-gradient(linear, left top, left bottom, color-stop(0%, #f8f8f8), color-stop(100%, #f5f5f5)) !important;background-image:-webkit-linear-gradient(top, #f8f8f8, #f5f5f5) !important;background-image:-o-linear-gradient(top, #f8f8f8, #f5f5f5) !important;background-image:-linear-gradient(top, #f8f8f8, #f5f5f5) !important;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#f8f8f8', endColorstr='#f5f5f5', GradientType=0) !important;border-color:#ccc !important}.admin-color-ectoplasm .ui-datepicker td .ui-state-active{color:black !important;font-weight:700 !important;background:white !important}.admin-color-ectoplasm .redux-container-switch .cb-disable.selected{background-color:#646464 !important;background-image:-khtml-gradient(linear, left top, left bottom, from(#929292), to(#646464)) !important;background-image:-moz-linear-gradient(top, #929292, #646464) !important;background-image:-ms-linear-gradient(top, #929292, #646464) !important;background-image:-webkit-gradient(linear, left top, left bottom, color-stop(0%, #929292), color-stop(100%, #646464)) !important;background-image:-webkit-linear-gradient(top, #929292, #646464) !important;background-image:-o-linear-gradient(top, #929292, #646464) !important;background-image:-linear-gradient(top, #929292, #646464) !important;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#929292', endColorstr='#646464', GradientType=0) !important;border-color:#767676 !important}.admin-color-ectoplasm .redux-container-switch .cb-enable.selected,.admin-color-ectoplasm .redux-field-container .ui-buttonset .ui-state-active{background-color:#a3b745 !important;background-image:-khtml-gradient(linear, left top, left bottom, from(#b0c25e), to(#a3b745)) !important;background-image:-moz-linear-gradient(top, #b0c25e, #a3b745) !important;background-image:-ms-linear-gradient(top, #b0c25e, #a3b745) !important;background-image:-webkit-gradient(linear, left top, left bottom, color-stop(0%, #b0c25e), color-stop(100%, #a3b745)) !important;background-image:-webkit-linear-gradient(top, #b0c25e, #a3b745) !important;background-image:-o-linear-gradient(top, #b0c25e, #a3b745) !important;background-image:-linear-gradient(top, #b0c25e, #a3b745) !important;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#b0c25e', endColorstr='#a3b745', GradientType=0) !important;border-color:#727f30 !important;border-color:#829237 !important;-webkit-box-shadow:inset 0 1px 0 #bfcd7b,0 1px 0 rgba(0,0,0,0.15) !important;box-shadow:inset 0 1px 0 #bfcd7b,0 1px 0 rgba(0,0,0,0.15) !important}.admin-color-ectoplasm #redux-header{background:#413256;border-color:#a3b745}.admin-color-ectoplasm #redux-header .display_header span{color:#cbc5d3}.admin-color-ectoplasm .redux-sidebar .redux-group-menu li.active.hasSubSections a{position:relative}.admin-color-ectoplasm .redux-sidebar .redux-group-menu li.active.hasSubSections a:after{right:0;border:solid 8px transparent;content:"\0020";height:0;width:0;position:absolute;pointer-events:none;border-right-color:#fff;top:50%;margin-top:-8px}.admin-color-ectoplasm .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li a:after{border:0 none !important;content:"\0020" !important}.admin-color-ectoplasm .redux-sidebar .redux-group-menu li.hasSubSections .redux-menu-error{display:none;margin-right:5px}.admin-color-ectoplasm .redux-sidebar .redux-group-menu li.hasSubSections a.hasError .extraIconSubsections{background-color:#b94a48;color:#f2dede}.admin-color-ectoplasm .redux-sidebar .redux-group-menu li.hasSubSections a .extraIconSubsections{border-radius:10px;-moz-border-radius:10px;-webkit-border-radius:10px;border:0 solid transparent;float:right;font-size:9px;height:9px;line-height:9px;margin-right:5px;padding:6px 7px 4px 7px;width:5px}.admin-color-ectoplasm .redux-sidebar .redux-group-menu li.active a .extraIconSubsections,.admin-color-ectoplasm .redux-sidebar .redux-group-menu li.activeChild a .extraIconSubsections{display:none}.admin-color-ectoplasm .redux-sidebar .redux-group-menu li.active.hasSubSections .redux-menu-error,.admin-color-ectoplasm .redux-sidebar .redux-group-menu li.activeChild.hasSubSections .redux-menu-error{display:block}.admin-color-ectoplasm .redux-sidebar .redux-group-menu li.active.hasSubSections .subsection .redux-menu-error,.admin-color-ectoplasm .redux-sidebar .redux-group-menu li.activeChild.hasSubSections .subsection .redux-menu-error{margin-right:2px}.admin-color-ectoplasm .redux-sidebar .redux-group-menu li.active,.admin-color-ectoplasm .redux-sidebar .redux-group-menu li.activeChild{border-left:0 none}.admin-color-ectoplasm .redux-sidebar .redux-group-menu li.active a,.admin-color-ectoplasm .redux-sidebar .redux-group-menu li.activeChild a{color:#413256}.admin-color-ectoplasm .redux-sidebar .redux-group-menu li.active.hasSubSections .active a:after,.admin-color-ectoplasm .redux-sidebar .redux-group-menu li.activeChild.hasSubSections .active a:after{right:0;border:solid 8px transparent;content:"\0020";height:0;width:0;position:absolute;pointer-events:none;border-right-color:#fff;top:50%;margin-top:-8px}.admin-color-ectoplasm .redux-sidebar .redux-group-menu li.active.hasSubSections a,.admin-color-ectoplasm .redux-sidebar .redux-group-menu li.activeChild.hasSubSections a{-webkit-transition:all 0.2s;-moz-transition:all 0.2s;transition:all 0.2s;color:#fff;width:auto;border-bottom:0}.admin-color-ectoplasm .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li,.admin-color-ectoplasm .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li{border-top:0 none !important}.admin-color-ectoplasm .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li.active a:hover,.admin-color-ectoplasm .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li.active a:hover{color:#fff}.admin-color-ectoplasm .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li a,.admin-color-ectoplasm .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li a{width:auto;border-top:0 !important;padding:7px;color:#fff;padding-left:15px;-webkit-transition:all 0.2;-moz-transition:all 0.2;-ms-transition:all 0.2;-o-transition:all 0.2;transition:all 0.2}.admin-color-ectoplasm .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li a:hover,.admin-color-ectoplasm .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li a:hover{color:#89993a;background:#291f36}.admin-color-ectoplasm .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li a span.group_title,.admin-color-ectoplasm .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li a span.group_title{padding-left:5px !important}.admin-color-ectoplasm .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li.hasIcon a,.admin-color-ectoplasm .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li.hasIcon a{padding-left:14px}.admin-color-ectoplasm .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li.hasIcon a span.group_title,.admin-color-ectoplasm .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li.hasIcon a span.group_title{padding-left:30px !important}.admin-color-ectoplasm .redux-sidebar .redux-group-menu li.active.hasSubSections a{background:#a3b745}.admin-color-ectoplasm .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li a{background:#413256}.admin-color-ectoplasm .redux-sidebar .redux-group-menu li.activeChild.hasSubSections a{background:#cbc5d3;text-shadow:1px 1px #7d6e91}.admin-color-ectoplasm .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li a{background:#413256;text-shadow:none}.admin-color-ectoplasm .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li.active a{background:#a3b745;text-shadow:1px 1px #616d29}.admin-color-ectoplasm .redux-container-image_select .redux-image-select-selected img{border-color:#a3b745}.admin-color-ectoplasm #redux-footer #redux-share a{color:#a3b745}.admin-color-ectoplasm #redux-footer #redux-share a:hover{color:#616d29}.admin-color-ectoplasm .select2-results .select2-highlighted{background:#a3b745}.admin-color-ectoplasm .select2-drop-active,.admin-color-ectoplasm .select2-container-multi.select2-container-active .select2-choices,.admin-color-ectoplasm .select2-drop.select2-drop-above.select2-drop-active,.admin-color-ectoplasm .select2-container-active .select2-choice,.admin-color-ectoplasm .select2-container-active .select2-choices,.admin-color-ectoplasm .select2-dropdown-open.select2-drop-above .select2-choice,.admin-color-ectoplasm .select2-dropdown-open.select2-drop-above .select2-choices{border-color:#a3b745}.admin-color-ectoplasm .select2-dropdown-open.select2-drop-above .select2-choice,.admin-color-ectoplasm .select2-dropdown-open.select2-drop-above .select2-choices{border-top:inherit}.admin-color-ectoplasm .noUi-connect{background-color:#a9bd4f !important;background-image:-khtml-gradient(linear, left top, left bottom, from(#b6c669), to(#a9bd4f)) !important;background-image:-moz-linear-gradient(top, #b6c669, #a9bd4f) !important;background-image:-ms-linear-gradient(top, #b6c669, #a9bd4f) !important;background-image:-webkit-gradient(linear, left top, left bottom, color-stop(0%, #b6c669), color-stop(100%, #a9bd4f)) !important;background-image:-webkit-linear-gradient(top, #b6c669, #a9bd4f) !important;background-image:-o-linear-gradient(top, #b6c669, #a9bd4f) !important;background-image:-linear-gradient(top, #b6c669, #a9bd4f) !important;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#b6c669', endColorstr='#a9bd4f', GradientType=0) !important}.admin-color-midnight .button.ui-datepicker-current,.admin-color-midnight button.ui-datepicker-close{background-color:#e35950 !important}.admin-color-midnight .ui-datepicker-buttonpane button.ui-datepicker-current{background:#d92c23 !important;color:white !important;border:1px solid #811a15 !important}.admin-color-midnight .ui-datepicker-header .ui-icon{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAQAAAADwCAMAAADYSUr5AAAA7VBMVEX8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vywC3+8AAAATnRSTlMAGBAyBAhQv4OZLiJUcEBmYBoSzQwgPBZCSEoeWiYwUiyFNIeBw2rJz8c4RBy9uXyrtaWNqa2zKP2fJO8KBgKPo2KVoa9s351GPm5+kWho0kj9AAAPhUlEQVR4nO1djWLbthEGyUiq5YSSLXtp7FpLOmfzkmxr126tmi2p03RJ1/Xe/3EGgARxPyAgRbIk2/hkSz4CJO4+HsE7AJSVysjI2AMUUOxahZ2iANhzBtZWr4BoIRSYAVN5u4QwDwQDRbcwfUi5KS3wFuDmFnQLa4Dtb//cqktwD5QEFFwfUs7PoCCA7y4bEJVFizcIob8KmhAplwwqVjt+9FBl3uINQniwEiryEyw9JHqGpQdEFNi+B4QQ7QOiHhysIPoAxUqxvdvvA9K42bsAv4S2fxfYOe57IJSRkZGRkZGxx7jxSHDHcRBXQMTyIjInBgHwBJ/bEx8PEANC+uhbpSSggCBAVODVabpI1S/k4WLZpTn6NpMhoX9Y40hxYERFpMcqUs4AloCtDQdID1YhnyXZ2hLjAYWiO9Dy1PDB7tPhIqLx+uMB8grZaR+Qxl2/C2RkZGRkZGRk7A7rBf7J0DR5/LUTjzUPIPSPGvQJiVJiB7kcQCiUOJrcFNtDZIf2xarQ3aGvLNxAVIFAabz90BFiBIlycTBhgWwOWCH0FLYHlPqwHaCvcIn2ZbosCevfPTRiFFcgvHukCjWwrc3GrGh1fsAof8EaUReKXkCB4/MzFNo97qLpFiKFYv/kNR5YQxQbQEofkZ2OuEOHqqT6gFTpru8CN7x/+jaZkZGRkZGRcV+x/rLUNcMMqUAscgnFocmpqkTzqymwVAPxfJ5PnIUUQOUKT04tEdWZyv3JCQSn96WS4pD97QfyW25A7NhSAbyhmVj0FEltA4vdiygBibXhoUYgykCUP7HwPTDeEqAIcHVMkZg7Zx4k0uFANs63hPQXCoRLAwdgGsr9Az7Qv7sgQGgg1aPl/BJLExBWgG4RFRLFImGmIquPC/klEGyCG0AuAXaJJC+B8FVe9NYQDEcXB8g6AQcjYJ1goJIggHWCrFR0S6kRHN5+4BzFi8NaoN35NRxUvL+JJdZr7PV4wK6fj8nIyMjIyNhr3OxdXAYq7FHZwB6bDSzSh4sF0utChqo0NAvaT1hLzXwFinmCzmeDucEQK18TTaQoFgP7bNC+RZ4OT4T6gQogDFYk+1QxQlj19QGSAWKiLYp8P0Ag1Gbz1ULfWHLg9iUnQNK5QQJcukm04blKLH2GgEJCY+HzXAZWCvHKco3Bp6MIaCjSXXRJyOxeqhnzEaF93MfFGW/O16ZvDL5TM4MJIjujz/cHypkQuuzRwWJ93BKdIt+wCRAPl9kpe2Ikkb2mFgGlxh/i40d3EHfdvoyMjIyMu43ylt/IAmGHnN5iIt7wKfbv01RAcJqFRl9lcjYQSnbQqKgC4fYOwSJt6N6trE0twZ9kN/PqNpTQeICvr4TLsDYC06U7BMjshS+v1/aT7IwQYD5LcgRQXMT2FrBfBLjZ6151jDElk9tPFfpUgk2yregusX25BJbwAFEfM+YI6vGAti4bTtizB+TjfQCrERyhKb2X8D6A9wX75P4t4neBYJeP6pdhg/gQl8MWvytzeSTjgOQBynQdh/iXKdxOrGJ/RkZGRsb9QmXihGr5+g8GGg9uTh+KoVZuNIzV+CwRucFBEyr1mVjx4irOxwM1BhirB6Q+2eNQi4eqR+aF6mELtoMzCR7V9RAFe/ZvQogNiyY8FPSUTFsLp8TeTmMui5mtw7bcaT0Yw2AA4wFRQIlkgq+1DQrNhkmoxS5Jq+u6bMAIGRECEANgXHTgWzwgBOhDH2l0oTQ4D8D5NMktBgNywAEMjo8rwATMZrPY7JGxBoJCkIBDQiAY09EGTUiBCWkUpISfGPR5AAwBfZiG2z7Ayc1yeKTxid39xBNwfHr4O0LA48ePFTvhYrF1r4tyAoz9n2MCqEuBtp/6GDR0oAYfG/R6wJExHYZHfhygsv7fEWCOj4bYmsP5A+pL4MkTfAnMlD4F+r3bobKvTyTA2P/w7PN+Agq2QW8piqMCpTBwenoKvX0AHGkGtP2YAPvTEWA7QUTAudn7/NxtOG46wWNmDtpBEkBzN7rBEvAFHp+YTB/q97qPAN4gHFqgBi8uLsC7qPCA6mg41G/+ErByPwEXDdoNxRhOx+M5jPEzQugS0ht+b1/Y3gEnYMAIAOIBE29/hIDucE8tmMsNOgK4B1RHFu4UCRlMHzv0xzcajcfdXWDs2h8TArBCkoDUJYDLmz6w7ip3BFS0ve5wTRwAn6keMA9I3QYbfSZ0DKbyt+7OXjGI1idPcfNyAyfAMlCrzaGqphYrxHocLHRJVycnfGUcbtT+jIyMjIw9x7Nn8fJSzG0TmFtO8rZT+XT3S3ub+tKJbbLd5diTVp50+zahyeHSslJ/YPrU0fuazrZO2CZ92/ZCCVXlGRiZKPJyPPRxyIFWeXLQBXJBKiq/3divEAN6ZwM200Qjm7EJBZeWm/PRWVCbYK7s7u2l4XaCz+lzgOfMfhMonXr7TWzeZb98dbgIzBT8Ub8eYYUqfZ4rVJ/MDbIDgPqTulJ/xvntWAtjIisqnwxOkGz0n077FARoY79GdA6HPE4rOy196NiMWHTZlSSApcOgXpy/fHV2joaNKu3ffsAnRcBf4K/6NcIG6tIxk3HyoXPjASqfUgXbYN5PzpL2njkR9QMjeDTVHDTCgRuxOegjoO0FvKzP/t/gmVdI24+G7NIe8JX6Wv3dDyldMA+4YB5wwTygtd+dwRqaTqrLb1l73zTSN52CNpnHuQOYPsDblybgxfkXh/oVtr+N1DEBJdhRJyd/Bd/q1z+cbNrD17iVKyajcnv9arhOkRPgsruuD6DmNPwpDNrLw2CoTgHni4yALr0L29+tiKAEIPn868ejx//8rpWP3OEOl5On9OwpcQm0MhafP/ey8f1uvDNIgGLQG8z4YO99ENgg95etwv4uYJYY8fUGHYH6j6fscHFZMftlAl9i+9XL73X3N/n+ZStOzfVfRvYXhrbdKOpEgVQTg/wsDuDD3kwOfQNMTJ5y+/ltUDWLunyxnRF46IqlBzGMY4X7inggREFioIyMjIyMHWCIB6ZNKAcXseo3vLTQTkVE7348dlwJJSz0+wLfmi8BhZqfw3D4ww/wHVLnEd5/fgYvXsDZ3MlsvYUbbnDjDZ3MN3TJG4+bxjAaDl8TBri9qxEw1ccao2wTNAMLHo2f+sjrXwb/9qHoYqgPMBXJTVfOpmrZH23y6uvo0LHSyY6fHGwKfHJlAuMFvObjDYrIqxBgQi20h7Hd/nYVLmno+eaNUm/eeH2GCuopntnhBJAlI2AHo9CCh1I1QxUdAbqqGY9BBLwyc3W4wYVhvY8A4BoIc1l5M7vnPWphZW9/Ses3n37y9a0uGqFwFQZsQQbd386DogpgEk+dzynsAZMJXq8+ns9NeukJ0PYrNATGGefJQlhkLo7DTXr+y3bNiOsDvrXTz/C2q1DXZH84iRNwrP88Nj+u2DjYEE6RBxD9Knj16ujVHC67A7422o02RwD3gB+t7EblWvu9geOFxSnd3ROmT+nJyQkhoPlsxVONc/3TEdBos+jtA+ZzcwHgTvD1cDjaYCcItA8w9i88A8b+mqSjc6Pvqd998QguEQPmQMeo23ODN86+p0/bn1buBkT6+oBhNZ/PYY4ZAHYb3PRd4LkZmPX68NRtMZn4ASvdA+qf0jMA5MP9eeg28Nug9QiLnj5A33U1MAES6xHAUNpz/9zFAYE1gqQDMT3G6xI9pwdw/aIgKoHCS1YGlRnSq9yCjdXjgN3j+N27YyROHxmuNAeNKPpYuXIyIyMjYy0M8eros59MF/PT2c602T7eA7zvhJ9dr/vzDjXaLp4Yc5+0wllzxzHv3gdmMMM7/CcQzKgVBqYTmFn+Z+mKm8J7k0A5F/jgCfjQ1WBhQyiOqD0lYuqBb+AyzMw9Ha2G3m6c8qQx+AlqnIceQp+Sb6i9UyQWbhr54+AjnZ0VzW2TAN0DmBT6PWmc6jDBE2PK2u+nF43dyP7Q0t1pOcX2fdRvH0mF2Q4JqN35rnHjVIeaXfIAVyUuw/aHCCiJy9iF5l1621zweI8KZrPZ9iJdb7DXJ3US0OSrtZ10imt7wHY7QesAzUMz1oZ3noB3qFJ/H18j97FYuw8QDN4oeKf30osvcSW2ExLo+VcbuAuo/sUIm8fMG9xocO3Ea19J9gFYivnHJ2KnyfovZlgW3v6ySx32abQiIyMjIyPjhlFDTLxpwIgFMnTp6A3g4IDKNY+stkwAMAoIAbasxBXqUWneSAWTMjt50lTqT29rFjvXohjsDNm2YPXDFlICmrJOZ3t6tHm8AiEAl0sCeLIIorIRt+cFbew/QRsoAXb4o1XSfoywzm0FTMAoYBNvLyFu8v8HpLBtD1iKgC17wHb7AI6d9wFbvguAIGTHd4E9wG7jgIyMjIyM+434c2R3HeV/Ffx6jtZu6ijl8h59T655jhR+rdHzDOP6beABCheb8O8/WFXeOyzgf5oAhVYnKxP7CwaAf1afJu8bSrhS6tdaXeGnrRenOqOlz9d6QwYnA/3TLd+GE7qe3chA5YF5DfY0vK3adfOX/gyNp2BW25MHdxAB9qvRiiP3/XpQQFGYDU4+Mi///XumXG8pjvaUAOsBGlf4jJt+YYEzeEzAdw06F19R3juM7D1wita86GR0CKfDHgLuXCc4Bri6vMLdfjMc4VNSUNsdodo2xu/1+Xl/K5+az8jIyMhYG/z5gJTMF1GtKq/a3rpyCvz5gJTMl9GtKq/a3rpyCmfQ4WwZmS+kXFVetb115ST48wEf/AGcfG1iw+tWbpbS2vJ3nQxcVr3lH3z5h972FUTLzYpOVk7l5hD+eYcYwDcAnewOotrZ4OtrPDucqi/LRX0/RR4qx7Nn4U8g+qjffvuN6Gf+nC85vwauHjaYyubqvWYKY4VEfSUMitdnBCT1Ue63R5439m+OgCn6DroAAaHPVQxKth/wkJgHmG8bmQMsT0D6EjDfvhVRKO3ywOQUgRA7nmL1uawZmHf1k+DPBwQ6NdcJ+k6Md1LA5f5ONdhJ8vZ5J0vLHT99srkGOjmJbd/G1r2Nriqnse1AZt1AalU5jW2HsuuG0qvKGRkZGRkZGRG0gcONyXsP9v8D0/IdJADiBNiXl3327WRGgOL/9HC/0XwlIURkRhC4tz6Z/fu7fUf2gHvfB9z3u0BGRkZGRkbGplHcnkgguQoSqtUXuhbs/wPtMwqV0HUJAvj5vk32b8IDuL23yn7qAXZ5u32hbRX7d3o82Df1FZXvbh9QOfhyxldr/+3xgXU9oKmvsHyr7F/XA269/eveBXrsv7N9QALe/tvjA0kPWAXGbvebkbHn+D/J5nMcHzx1UAAAAABJRU5ErkJggg==) !important}.admin-color-midnight .ui-datepicker-header{background-color:#363b3f !important;color:white !important}.admin-color-midnight .ui-datepicker td .ui-state-active{background-color:#e35950 !important;color:white !important}.admin-color-midnight .ui-datepicker td .ui-state-hover{color:#e35950 !important}.admin-color-midnight .ui-datepicker td .ui-state-highlight{background:#e14d43 !important;border:1px solid #363b3f !important;color:white !important}.admin-color-midnight .redux-container-switch .cb-disable,.admin-color-midnight .redux-container-switch .cb-enable,.admin-color-midnight .ui-state-default,.admin-color-midnight .ui-widget-content .ui-state-default,.admin-color-midnight .ui-widget-header .ui-state-default{background-color:#f5f5f5 !important;background-image:-khtml-gradient(linear, left top, left bottom, from(#f8f8f8), to(#f5f5f5)) !important;background-image:-moz-linear-gradient(top, #f8f8f8, #f5f5f5) !important;background-image:-ms-linear-gradient(top, #f8f8f8, #f5f5f5) !important;background-image:-webkit-gradient(linear, left top, left bottom, color-stop(0%, #f8f8f8), color-stop(100%, #f5f5f5)) !important;background-image:-webkit-linear-gradient(top, #f8f8f8, #f5f5f5) !important;background-image:-o-linear-gradient(top, #f8f8f8, #f5f5f5) !important;background-image:-linear-gradient(top, #f8f8f8, #f5f5f5) !important;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#f8f8f8', endColorstr='#f5f5f5', GradientType=0) !important;border-color:#ccc !important}.admin-color-midnight .ui-datepicker td .ui-state-active{color:black !important;font-weight:700 !important;background:white !important}.admin-color-midnight .redux-container-switch .cb-disable.selected{background-color:#646464 !important;background-image:-khtml-gradient(linear, left top, left bottom, from(#929292), to(#646464)) !important;background-image:-moz-linear-gradient(top, #929292, #646464) !important;background-image:-ms-linear-gradient(top, #929292, #646464) !important;background-image:-webkit-gradient(linear, left top, left bottom, color-stop(0%, #929292), color-stop(100%, #646464)) !important;background-image:-webkit-linear-gradient(top, #929292, #646464) !important;background-image:-o-linear-gradient(top, #929292, #646464) !important;background-image:-linear-gradient(top, #929292, #646464) !important;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#929292', endColorstr='#646464', GradientType=0) !important;border-color:#767676 !important}.admin-color-midnight .redux-container-switch .cb-enable.selected,.admin-color-midnight .redux-field-container .ui-buttonset .ui-state-active{background-color:#e14d43 !important;background-image:-khtml-gradient(linear, left top, left bottom, from(#e66a62), to(#e14d43)) !important;background-image:-moz-linear-gradient(top, #e66a62, #e14d43) !important;background-image:-ms-linear-gradient(top, #e66a62, #e14d43) !important;background-image:-webkit-gradient(linear, left top, left bottom, color-stop(0%, #e66a62), color-stop(100%, #e14d43)) !important;background-image:-webkit-linear-gradient(top, #e66a62, #e14d43) !important;background-image:-o-linear-gradient(top, #e66a62, #e14d43) !important;background-image:-linear-gradient(top, #e66a62, #e14d43) !important;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#e66a62', endColorstr='#e14d43', GradientType=0) !important;border-color:#ba281e !important;border-color:#d02c21 !important;-webkit-box-shadow:inset 0 1px 0 #ec8b85,0 1px 0 rgba(0,0,0,0.15) !important;box-shadow:inset 0 1px 0 #ec8b85,0 1px 0 rgba(0,0,0,0.15) !important}.admin-color-midnight #redux-header{background:#363b3f;border-color:#e14d43}.admin-color-midnight #redux-header .display_header span{color:#c2c4c5}.admin-color-midnight .redux-sidebar .redux-group-menu li.active.hasSubSections a{position:relative}.admin-color-midnight .redux-sidebar .redux-group-menu li.active.hasSubSections a:after{right:0;border:solid 8px transparent;content:"\0020";height:0;width:0;position:absolute;pointer-events:none;border-right-color:#fff;top:50%;margin-top:-8px}.admin-color-midnight .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li a:after{border:0 none !important;content:"\0020" !important}.admin-color-midnight .redux-sidebar .redux-group-menu li.hasSubSections .redux-menu-error{display:none;margin-right:5px}.admin-color-midnight .redux-sidebar .redux-group-menu li.hasSubSections a.hasError .extraIconSubsections{background-color:#b94a48;color:#f2dede}.admin-color-midnight .redux-sidebar .redux-group-menu li.hasSubSections a .extraIconSubsections{border-radius:10px;-moz-border-radius:10px;-webkit-border-radius:10px;border:0 solid transparent;float:right;font-size:9px;height:9px;line-height:9px;margin-right:5px;padding:6px 7px 4px 7px;width:5px}.admin-color-midnight .redux-sidebar .redux-group-menu li.active a .extraIconSubsections,.admin-color-midnight .redux-sidebar .redux-group-menu li.activeChild a .extraIconSubsections{display:none}.admin-color-midnight .redux-sidebar .redux-group-menu li.active.hasSubSections .redux-menu-error,.admin-color-midnight .redux-sidebar .redux-group-menu li.activeChild.hasSubSections .redux-menu-error{display:block}.admin-color-midnight .redux-sidebar .redux-group-menu li.active.hasSubSections .subsection .redux-menu-error,.admin-color-midnight .redux-sidebar .redux-group-menu li.activeChild.hasSubSections .subsection .redux-menu-error{margin-right:2px}.admin-color-midnight .redux-sidebar .redux-group-menu li.active,.admin-color-midnight .redux-sidebar .redux-group-menu li.activeChild{border-left:0 none}.admin-color-midnight .redux-sidebar .redux-group-menu li.active a,.admin-color-midnight .redux-sidebar .redux-group-menu li.activeChild a{color:#363b3f}.admin-color-midnight .redux-sidebar .redux-group-menu li.active.hasSubSections .active a:after,.admin-color-midnight .redux-sidebar .redux-group-menu li.activeChild.hasSubSections .active a:after{right:0;border:solid 8px transparent;content:"\0020";height:0;width:0;position:absolute;pointer-events:none;border-right-color:#fff;top:50%;margin-top:-8px}.admin-color-midnight .redux-sidebar .redux-group-menu li.active.hasSubSections a,.admin-color-midnight .redux-sidebar .redux-group-menu li.activeChild.hasSubSections a{-webkit-transition:all 0.2s;-moz-transition:all 0.2s;transition:all 0.2s;color:#fff;width:auto;border-bottom:0}.admin-color-midnight .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li,.admin-color-midnight .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li{border-top:0 none !important}.admin-color-midnight .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li.active a:hover,.admin-color-midnight .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li.active a:hover{color:#fff}.admin-color-midnight .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li a,.admin-color-midnight .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li a{width:auto;border-top:0 !important;padding:7px;color:#fff;padding-left:15px;-webkit-transition:all 0.2;-moz-transition:all 0.2;-ms-transition:all 0.2;-o-transition:all 0.2;transition:all 0.2}.admin-color-midnight .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li a:hover,.admin-color-midnight .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li a:hover{color:#d92c23;background:#1e2124}.admin-color-midnight .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li a span.group_title,.admin-color-midnight .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li a span.group_title{padding-left:5px !important}.admin-color-midnight .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li.hasIcon a,.admin-color-midnight .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li.hasIcon a{padding-left:14px}.admin-color-midnight .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li.hasIcon a span.group_title,.admin-color-midnight .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li.hasIcon a span.group_title{padding-left:30px !important}.admin-color-midnight .redux-sidebar .redux-group-menu li.active.hasSubSections a{background:#e14d43}.admin-color-midnight .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li a{background:#363b3f}.admin-color-midnight .redux-sidebar .redux-group-menu li.activeChild.hasSubSections a{background:#c2c4c5;text-shadow:1px 1px #74787a}.admin-color-midnight .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li a{background:#363b3f;text-shadow:none}.admin-color-midnight .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li.active a{background:#e14d43;text-shadow:1px 1px #a4231a}.admin-color-midnight .redux-container-image_select .redux-image-select-selected img{border-color:#e14d43}.admin-color-midnight #redux-footer #redux-share a{color:#e14d43}.admin-color-midnight #redux-footer #redux-share a:hover{color:#a4231a}.admin-color-midnight .select2-results .select2-highlighted{background:#e14d43}.admin-color-midnight .select2-drop-active,.admin-color-midnight .select2-container-multi.select2-container-active .select2-choices,.admin-color-midnight .select2-drop.select2-drop-above.select2-drop-active,.admin-color-midnight .select2-container-active .select2-choice,.admin-color-midnight .select2-container-active .select2-choices,.admin-color-midnight .select2-dropdown-open.select2-drop-above .select2-choice,.admin-color-midnight .select2-dropdown-open.select2-drop-above .select2-choices{border-color:#e14d43}.admin-color-midnight .select2-dropdown-open.select2-drop-above .select2-choice,.admin-color-midnight .select2-dropdown-open.select2-drop-above .select2-choices{border-top:inherit}.admin-color-midnight .noUi-connect{background-color:#e35950 !important;background-image:-khtml-gradient(linear, left top, left bottom, from(#e8776f), to(#e35950)) !important;background-image:-moz-linear-gradient(top, #e8776f, #e35950) !important;background-image:-ms-linear-gradient(top, #e8776f, #e35950) !important;background-image:-webkit-gradient(linear, left top, left bottom, color-stop(0%, #e8776f), color-stop(100%, #e35950)) !important;background-image:-webkit-linear-gradient(top, #e8776f, #e35950) !important;background-image:-o-linear-gradient(top, #e8776f, #e35950) !important;background-image:-linear-gradient(top, #e8776f, #e35950) !important;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#e8776f', endColorstr='#e35950', GradientType=0) !important}.admin-color-ocean .button.ui-datepicker-current,.admin-color-ocean button.ui-datepicker-close{background-color:#a7c0a9 !important}.admin-color-ocean .ui-datepicker-buttonpane button.ui-datepicker-current{background:#86a988 !important;color:white !important;border:1px solid #547555 !important}.admin-color-ocean .ui-datepicker-header .ui-icon{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAQAAAADwCAMAAADYSUr5AAAA7VBMVEX8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vywC3+8AAAATnRSTlMAGBAyBAhQv4OZLiJUcEBmYBoSzQwgPBZCSEoeWiYwUiyFNIeBw2rJz8c4RBy9uXyrtaWNqa2zKP2fJO8KBgKPo2KVoa9s351GPm5+kWho0kj9AAAPhUlEQVR4nO1djWLbthEGyUiq5YSSLXtp7FpLOmfzkmxr126tmi2p03RJ1/Xe/3EGgARxPyAgRbIk2/hkSz4CJO4+HsE7AJSVysjI2AMUUOxahZ2iANhzBtZWr4BoIRSYAVN5u4QwDwQDRbcwfUi5KS3wFuDmFnQLa4Dtb//cqktwD5QEFFwfUs7PoCCA7y4bEJVFizcIob8KmhAplwwqVjt+9FBl3uINQniwEiryEyw9JHqGpQdEFNi+B4QQ7QOiHhysIPoAxUqxvdvvA9K42bsAv4S2fxfYOe57IJSRkZGRkZGxx7jxSHDHcRBXQMTyIjInBgHwBJ/bEx8PEANC+uhbpSSggCBAVODVabpI1S/k4WLZpTn6NpMhoX9Y40hxYERFpMcqUs4AloCtDQdID1YhnyXZ2hLjAYWiO9Dy1PDB7tPhIqLx+uMB8grZaR+Qxl2/C2RkZGRkZGRk7A7rBf7J0DR5/LUTjzUPIPSPGvQJiVJiB7kcQCiUOJrcFNtDZIf2xarQ3aGvLNxAVIFAabz90BFiBIlycTBhgWwOWCH0FLYHlPqwHaCvcIn2ZbosCevfPTRiFFcgvHukCjWwrc3GrGh1fsAof8EaUReKXkCB4/MzFNo97qLpFiKFYv/kNR5YQxQbQEofkZ2OuEOHqqT6gFTpru8CN7x/+jaZkZGRkZGRcV+x/rLUNcMMqUAscgnFocmpqkTzqymwVAPxfJ5PnIUUQOUKT04tEdWZyv3JCQSn96WS4pD97QfyW25A7NhSAbyhmVj0FEltA4vdiygBibXhoUYgykCUP7HwPTDeEqAIcHVMkZg7Zx4k0uFANs63hPQXCoRLAwdgGsr9Az7Qv7sgQGgg1aPl/BJLExBWgG4RFRLFImGmIquPC/klEGyCG0AuAXaJJC+B8FVe9NYQDEcXB8g6AQcjYJ1goJIggHWCrFR0S6kRHN5+4BzFi8NaoN35NRxUvL+JJdZr7PV4wK6fj8nIyMjIyNhr3OxdXAYq7FHZwB6bDSzSh4sF0utChqo0NAvaT1hLzXwFinmCzmeDucEQK18TTaQoFgP7bNC+RZ4OT4T6gQogDFYk+1QxQlj19QGSAWKiLYp8P0Ag1Gbz1ULfWHLg9iUnQNK5QQJcukm04blKLH2GgEJCY+HzXAZWCvHKco3Bp6MIaCjSXXRJyOxeqhnzEaF93MfFGW/O16ZvDL5TM4MJIjujz/cHypkQuuzRwWJ93BKdIt+wCRAPl9kpe2Ikkb2mFgGlxh/i40d3EHfdvoyMjIyMu43ylt/IAmGHnN5iIt7wKfbv01RAcJqFRl9lcjYQSnbQqKgC4fYOwSJt6N6trE0twZ9kN/PqNpTQeICvr4TLsDYC06U7BMjshS+v1/aT7IwQYD5LcgRQXMT2FrBfBLjZ6151jDElk9tPFfpUgk2yregusX25BJbwAFEfM+YI6vGAti4bTtizB+TjfQCrERyhKb2X8D6A9wX75P4t4neBYJeP6pdhg/gQl8MWvytzeSTjgOQBynQdh/iXKdxOrGJ/RkZGRsb9QmXihGr5+g8GGg9uTh+KoVZuNIzV+CwRucFBEyr1mVjx4irOxwM1BhirB6Q+2eNQi4eqR+aF6mELtoMzCR7V9RAFe/ZvQogNiyY8FPSUTFsLp8TeTmMui5mtw7bcaT0Yw2AA4wFRQIlkgq+1DQrNhkmoxS5Jq+u6bMAIGRECEANgXHTgWzwgBOhDH2l0oTQ4D8D5NMktBgNywAEMjo8rwATMZrPY7JGxBoJCkIBDQiAY09EGTUiBCWkUpISfGPR5AAwBfZiG2z7Ayc1yeKTxid39xBNwfHr4O0LA48ePFTvhYrF1r4tyAoz9n2MCqEuBtp/6GDR0oAYfG/R6wJExHYZHfhygsv7fEWCOj4bYmsP5A+pL4MkTfAnMlD4F+r3bobKvTyTA2P/w7PN+Agq2QW8piqMCpTBwenoKvX0AHGkGtP2YAPvTEWA7QUTAudn7/NxtOG46wWNmDtpBEkBzN7rBEvAFHp+YTB/q97qPAN4gHFqgBi8uLsC7qPCA6mg41G/+ErByPwEXDdoNxRhOx+M5jPEzQugS0ht+b1/Y3gEnYMAIAOIBE29/hIDucE8tmMsNOgK4B1RHFu4UCRlMHzv0xzcajcfdXWDs2h8TArBCkoDUJYDLmz6w7ip3BFS0ve5wTRwAn6keMA9I3QYbfSZ0DKbyt+7OXjGI1idPcfNyAyfAMlCrzaGqphYrxHocLHRJVycnfGUcbtT+jIyMjIw9x7Nn8fJSzG0TmFtO8rZT+XT3S3ub+tKJbbLd5diTVp50+zahyeHSslJ/YPrU0fuazrZO2CZ92/ZCCVXlGRiZKPJyPPRxyIFWeXLQBXJBKiq/3divEAN6ZwM200Qjm7EJBZeWm/PRWVCbYK7s7u2l4XaCz+lzgOfMfhMonXr7TWzeZb98dbgIzBT8Ub8eYYUqfZ4rVJ/MDbIDgPqTulJ/xvntWAtjIisqnwxOkGz0n077FARoY79GdA6HPE4rOy196NiMWHTZlSSApcOgXpy/fHV2joaNKu3ffsAnRcBf4K/6NcIG6tIxk3HyoXPjASqfUgXbYN5PzpL2njkR9QMjeDTVHDTCgRuxOegjoO0FvKzP/t/gmVdI24+G7NIe8JX6Wv3dDyldMA+4YB5wwTygtd+dwRqaTqrLb1l73zTSN52CNpnHuQOYPsDblybgxfkXh/oVtr+N1DEBJdhRJyd/Bd/q1z+cbNrD17iVKyajcnv9arhOkRPgsruuD6DmNPwpDNrLw2CoTgHni4yALr0L29+tiKAEIPn868ejx//8rpWP3OEOl5On9OwpcQm0MhafP/ey8f1uvDNIgGLQG8z4YO99ENgg95etwv4uYJYY8fUGHYH6j6fscHFZMftlAl9i+9XL73X3N/n+ZStOzfVfRvYXhrbdKOpEgVQTg/wsDuDD3kwOfQNMTJ5y+/ltUDWLunyxnRF46IqlBzGMY4X7inggREFioIyMjIyMHWCIB6ZNKAcXseo3vLTQTkVE7348dlwJJSz0+wLfmi8BhZqfw3D4ww/wHVLnEd5/fgYvXsDZ3MlsvYUbbnDjDZ3MN3TJG4+bxjAaDl8TBri9qxEw1ccao2wTNAMLHo2f+sjrXwb/9qHoYqgPMBXJTVfOpmrZH23y6uvo0LHSyY6fHGwKfHJlAuMFvObjDYrIqxBgQi20h7Hd/nYVLmno+eaNUm/eeH2GCuopntnhBJAlI2AHo9CCh1I1QxUdAbqqGY9BBLwyc3W4wYVhvY8A4BoIc1l5M7vnPWphZW9/Ses3n37y9a0uGqFwFQZsQQbd386DogpgEk+dzynsAZMJXq8+ns9NeukJ0PYrNATGGefJQlhkLo7DTXr+y3bNiOsDvrXTz/C2q1DXZH84iRNwrP88Nj+u2DjYEE6RBxD9Knj16ujVHC67A7422o02RwD3gB+t7EblWvu9geOFxSnd3ROmT+nJyQkhoPlsxVONc/3TEdBos+jtA+ZzcwHgTvD1cDjaYCcItA8w9i88A8b+mqSjc6Pvqd998QguEQPmQMeo23ODN86+p0/bn1buBkT6+oBhNZ/PYY4ZAHYb3PRd4LkZmPX68NRtMZn4ASvdA+qf0jMA5MP9eeg28Nug9QiLnj5A33U1MAES6xHAUNpz/9zFAYE1gqQDMT3G6xI9pwdw/aIgKoHCS1YGlRnSq9yCjdXjgN3j+N27YyROHxmuNAeNKPpYuXIyIyMjYy0M8eros59MF/PT2c602T7eA7zvhJ9dr/vzDjXaLp4Yc5+0wllzxzHv3gdmMMM7/CcQzKgVBqYTmFn+Z+mKm8J7k0A5F/jgCfjQ1WBhQyiOqD0lYuqBb+AyzMw9Ha2G3m6c8qQx+AlqnIceQp+Sb6i9UyQWbhr54+AjnZ0VzW2TAN0DmBT6PWmc6jDBE2PK2u+nF43dyP7Q0t1pOcX2fdRvH0mF2Q4JqN35rnHjVIeaXfIAVyUuw/aHCCiJy9iF5l1621zweI8KZrPZ9iJdb7DXJ3US0OSrtZ10imt7wHY7QesAzUMz1oZ3noB3qFJ/H18j97FYuw8QDN4oeKf30osvcSW2ExLo+VcbuAuo/sUIm8fMG9xocO3Ea19J9gFYivnHJ2KnyfovZlgW3v6ySx32abQiIyMjIyPjhlFDTLxpwIgFMnTp6A3g4IDKNY+stkwAMAoIAbasxBXqUWneSAWTMjt50lTqT29rFjvXohjsDNm2YPXDFlICmrJOZ3t6tHm8AiEAl0sCeLIIorIRt+cFbew/QRsoAXb4o1XSfoywzm0FTMAoYBNvLyFu8v8HpLBtD1iKgC17wHb7AI6d9wFbvguAIGTHd4E9wG7jgIyMjIyM+434c2R3HeV/Ffx6jtZu6ijl8h59T655jhR+rdHzDOP6beABCheb8O8/WFXeOyzgf5oAhVYnKxP7CwaAf1afJu8bSrhS6tdaXeGnrRenOqOlz9d6QwYnA/3TLd+GE7qe3chA5YF5DfY0vK3adfOX/gyNp2BW25MHdxAB9qvRiiP3/XpQQFGYDU4+Mi///XumXG8pjvaUAOsBGlf4jJt+YYEzeEzAdw06F19R3juM7D1wita86GR0CKfDHgLuXCc4Bri6vMLdfjMc4VNSUNsdodo2xu/1+Xl/K5+az8jIyMhYG/z5gJTMF1GtKq/a3rpyCvz5gJTMl9GtKq/a3rpyCmfQ4WwZmS+kXFVetb115ST48wEf/AGcfG1iw+tWbpbS2vJ3nQxcVr3lH3z5h972FUTLzYpOVk7l5hD+eYcYwDcAnewOotrZ4OtrPDucqi/LRX0/RR4qx7Nn4U8g+qjffvuN6Gf+nC85vwauHjaYyubqvWYKY4VEfSUMitdnBCT1Ue63R5439m+OgCn6DroAAaHPVQxKth/wkJgHmG8bmQMsT0D6EjDfvhVRKO3ywOQUgRA7nmL1uawZmHf1k+DPBwQ6NdcJ+k6Md1LA5f5ONdhJ8vZ5J0vLHT99srkGOjmJbd/G1r2Nriqnse1AZt1AalU5jW2HsuuG0qvKGRkZGRkZGRG0gcONyXsP9v8D0/IdJADiBNiXl3327WRGgOL/9HC/0XwlIURkRhC4tz6Z/fu7fUf2gHvfB9z3u0BGRkZGRkbGplHcnkgguQoSqtUXuhbs/wPtMwqV0HUJAvj5vk32b8IDuL23yn7qAXZ5u32hbRX7d3o82Df1FZXvbh9QOfhyxldr/+3xgXU9oKmvsHyr7F/XA269/eveBXrsv7N9QALe/tvjA0kPWAXGbvebkbHn+D/J5nMcHzx1UAAAAABJRU5ErkJggg==) !important}.admin-color-ocean .ui-datepicker-header{background-color:#627c83 !important;color:white !important}.admin-color-ocean .ui-datepicker td .ui-state-active{background-color:#a7c0a9 !important;color:white !important}.admin-color-ocean .ui-datepicker td .ui-state-hover{color:#a7c0a9 !important}.admin-color-ocean .ui-datepicker td .ui-state-highlight{background:#9ebaa0 !important;border:1px solid #627c83 !important;color:white !important}.admin-color-ocean .redux-container-switch .cb-disable,.admin-color-ocean .redux-container-switch .cb-enable,.admin-color-ocean .ui-state-default,.admin-color-ocean .ui-widget-content .ui-state-default,.admin-color-ocean .ui-widget-header .ui-state-default{background-color:#f5f5f5 !important;background-image:-khtml-gradient(linear, left top, left bottom, from(#f8f8f8), to(#f5f5f5)) !important;background-image:-moz-linear-gradient(top, #f8f8f8, #f5f5f5) !important;background-image:-ms-linear-gradient(top, #f8f8f8, #f5f5f5) !important;background-image:-webkit-gradient(linear, left top, left bottom, color-stop(0%, #f8f8f8), color-stop(100%, #f5f5f5)) !important;background-image:-webkit-linear-gradient(top, #f8f8f8, #f5f5f5) !important;background-image:-o-linear-gradient(top, #f8f8f8, #f5f5f5) !important;background-image:-linear-gradient(top, #f8f8f8, #f5f5f5) !important;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#f8f8f8', endColorstr='#f5f5f5', GradientType=0) !important;border-color:#ccc !important}.admin-color-ocean .ui-datepicker td .ui-state-active{color:black !important;font-weight:700 !important;background:white !important}.admin-color-ocean .redux-container-switch .cb-disable.selected{background-color:#646464 !important;background-image:-khtml-gradient(linear, left top, left bottom, from(#929292), to(#646464)) !important;background-image:-moz-linear-gradient(top, #929292, #646464) !important;background-image:-ms-linear-gradient(top, #929292, #646464) !important;background-image:-webkit-gradient(linear, left top, left bottom, color-stop(0%, #929292), color-stop(100%, #646464)) !important;background-image:-webkit-linear-gradient(top, #929292, #646464) !important;background-image:-o-linear-gradient(top, #929292, #646464) !important;background-image:-linear-gradient(top, #929292, #646464) !important;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#929292', endColorstr='#646464', GradientType=0) !important;border-color:#767676 !important}.admin-color-ocean .redux-container-switch .cb-enable.selected,.admin-color-ocean .redux-field-container .ui-buttonset .ui-state-active{background-color:#9ebaa0 !important;background-image:-khtml-gradient(linear, left top, left bottom, from(#b3c9b4), to(#9ebaa0)) !important;background-image:-moz-linear-gradient(top, #b3c9b4, #9ebaa0) !important;background-image:-ms-linear-gradient(top, #b3c9b4, #9ebaa0) !important;background-image:-webkit-gradient(linear, left top, left bottom, color-stop(0%, #b3c9b4), color-stop(100%, #9ebaa0)) !important;background-image:-webkit-linear-gradient(top, #b3c9b4, #9ebaa0) !important;background-image:-o-linear-gradient(top, #b3c9b4, #9ebaa0) !important;background-image:-linear-gradient(top, #b3c9b4, #9ebaa0) !important;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#b3c9b4', endColorstr='#9ebaa0', GradientType=0) !important;border-color:#719a74 !important;border-color:#80a583 !important;-webkit-box-shadow:inset 0 1px 0 #cbdacc,0 1px 0 rgba(0,0,0,0.15) !important;box-shadow:inset 0 1px 0 #cbdacc,0 1px 0 rgba(0,0,0,0.15) !important}.admin-color-ocean #redux-header{background:#627c83;border-color:#9ebaa0}.admin-color-ocean #redux-header .display_header span{color:#d5dddf}.admin-color-ocean .redux-sidebar .redux-group-menu li.active.hasSubSections a{position:relative}.admin-color-ocean .redux-sidebar .redux-group-menu li.active.hasSubSections a:after{right:0;border:solid 8px transparent;content:"\0020";height:0;width:0;position:absolute;pointer-events:none;border-right-color:#fff;top:50%;margin-top:-8px}.admin-color-ocean .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li a:after{border:0 none !important;content:"\0020" !important}.admin-color-ocean .redux-sidebar .redux-group-menu li.hasSubSections .redux-menu-error{display:none;margin-right:5px}.admin-color-ocean .redux-sidebar .redux-group-menu li.hasSubSections a.hasError .extraIconSubsections{background-color:#b94a48;color:#f2dede}.admin-color-ocean .redux-sidebar .redux-group-menu li.hasSubSections a .extraIconSubsections{border-radius:10px;-moz-border-radius:10px;-webkit-border-radius:10px;border:0 solid transparent;float:right;font-size:9px;height:9px;line-height:9px;margin-right:5px;padding:6px 7px 4px 7px;width:5px}.admin-color-ocean .redux-sidebar .redux-group-menu li.active a .extraIconSubsections,.admin-color-ocean .redux-sidebar .redux-group-menu li.activeChild a .extraIconSubsections{display:none}.admin-color-ocean .redux-sidebar .redux-group-menu li.active.hasSubSections .redux-menu-error,.admin-color-ocean .redux-sidebar .redux-group-menu li.activeChild.hasSubSections .redux-menu-error{display:block}.admin-color-ocean .redux-sidebar .redux-group-menu li.active.hasSubSections .subsection .redux-menu-error,.admin-color-ocean .redux-sidebar .redux-group-menu li.activeChild.hasSubSections .subsection .redux-menu-error{margin-right:2px}.admin-color-ocean .redux-sidebar .redux-group-menu li.active,.admin-color-ocean .redux-sidebar .redux-group-menu li.activeChild{border-left:0 none}.admin-color-ocean .redux-sidebar .redux-group-menu li.active a,.admin-color-ocean .redux-sidebar .redux-group-menu li.activeChild a{color:#627c83}.admin-color-ocean .redux-sidebar .redux-group-menu li.active.hasSubSections .active a:after,.admin-color-ocean .redux-sidebar .redux-group-menu li.activeChild.hasSubSections .active a:after{right:0;border:solid 8px transparent;content:"\0020";height:0;width:0;position:absolute;pointer-events:none;border-right-color:#fff;top:50%;margin-top:-8px}.admin-color-ocean .redux-sidebar .redux-group-menu li.active.hasSubSections a,.admin-color-ocean .redux-sidebar .redux-group-menu li.activeChild.hasSubSections a{-webkit-transition:all 0.2s;-moz-transition:all 0.2s;transition:all 0.2s;color:#fff;width:auto;border-bottom:0}.admin-color-ocean .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li,.admin-color-ocean .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li{border-top:0 none !important}.admin-color-ocean .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li.active a:hover,.admin-color-ocean .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li.active a:hover{color:#fff}.admin-color-ocean .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li a,.admin-color-ocean .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li a{width:auto;border-top:0 !important;padding:7px;color:#fff;padding-left:15px;-webkit-transition:all 0.2;-moz-transition:all 0.2;-ms-transition:all 0.2;-o-transition:all 0.2;transition:all 0.2}.admin-color-ocean .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li a:hover,.admin-color-ocean .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li a:hover{color:#86a988;background:#4c6066}.admin-color-ocean .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li a span.group_title,.admin-color-ocean .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li a span.group_title{padding-left:5px !important}.admin-color-ocean .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li.hasIcon a,.admin-color-ocean .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li.hasIcon a{padding-left:14px}.admin-color-ocean .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li.hasIcon a span.group_title,.admin-color-ocean .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li.hasIcon a span.group_title{padding-left:30px !important}.admin-color-ocean .redux-sidebar .redux-group-menu li.active.hasSubSections a{background:#9ebaa0}.admin-color-ocean .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li a{background:#627c83}.admin-color-ocean .redux-sidebar .redux-group-menu li.activeChild.hasSubSections a{background:#d5dddf;text-shadow:1px 1px #7e979d}.admin-color-ocean .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li a{background:#627c83;text-shadow:none}.admin-color-ocean .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li.active a{background:#9ebaa0;text-shadow:1px 1px #658d68}.admin-color-ocean .redux-container-image_select .redux-image-select-selected img{border-color:#9ebaa0}.admin-color-ocean #redux-footer #redux-share a{color:#9ebaa0}.admin-color-ocean #redux-footer #redux-share a:hover{color:#658d68}.admin-color-ocean .select2-results .select2-highlighted{background:#9ebaa0}.admin-color-ocean .select2-drop-active,.admin-color-ocean .select2-container-multi.select2-container-active .select2-choices,.admin-color-ocean .select2-drop.select2-drop-above.select2-drop-active,.admin-color-ocean .select2-container-active .select2-choice,.admin-color-ocean .select2-container-active .select2-choices,.admin-color-ocean .select2-dropdown-open.select2-drop-above .select2-choice,.admin-color-ocean .select2-dropdown-open.select2-drop-above .select2-choices{border-color:#9ebaa0}.admin-color-ocean .select2-dropdown-open.select2-drop-above .select2-choice,.admin-color-ocean .select2-dropdown-open.select2-drop-above .select2-choices{border-top:inherit}.admin-color-ocean .noUi-connect{background-color:#a7c0a9 !important;background-image:-khtml-gradient(linear, left top, left bottom, from(#bccfbd), to(#a7c0a9)) !important;background-image:-moz-linear-gradient(top, #bccfbd, #a7c0a9) !important;background-image:-ms-linear-gradient(top, #bccfbd, #a7c0a9) !important;background-image:-webkit-gradient(linear, left top, left bottom, color-stop(0%, #bccfbd), color-stop(100%, #a7c0a9)) !important;background-image:-webkit-linear-gradient(top, #bccfbd, #a7c0a9) !important;background-image:-o-linear-gradient(top, #bccfbd, #a7c0a9) !important;background-image:-linear-gradient(top, #bccfbd, #a7c0a9) !important;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#bccfbd', endColorstr='#a7c0a9', GradientType=0) !important}.admin-color-sunrise .button.ui-datepicker-current,.admin-color-sunrise button.ui-datepicker-close{background-color:#df8a48 !important}.admin-color-sunrise .ui-datepicker-buttonpane button.ui-datepicker-current{background:#cc6c23 !important;color:white !important;border:1px solid #753e14 !important}.admin-color-sunrise .ui-datepicker-header .ui-icon{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAQAAAADwCAMAAADYSUr5AAAA7VBMVEX8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vywC3+8AAAATnRSTlMAGBAyBAhQv4OZLiJUcEBmYBoSzQwgPBZCSEoeWiYwUiyFNIeBw2rJz8c4RBy9uXyrtaWNqa2zKP2fJO8KBgKPo2KVoa9s351GPm5+kWho0kj9AAAPhUlEQVR4nO1djWLbthEGyUiq5YSSLXtp7FpLOmfzkmxr126tmi2p03RJ1/Xe/3EGgARxPyAgRbIk2/hkSz4CJO4+HsE7AJSVysjI2AMUUOxahZ2iANhzBtZWr4BoIRSYAVN5u4QwDwQDRbcwfUi5KS3wFuDmFnQLa4Dtb//cqktwD5QEFFwfUs7PoCCA7y4bEJVFizcIob8KmhAplwwqVjt+9FBl3uINQniwEiryEyw9JHqGpQdEFNi+B4QQ7QOiHhysIPoAxUqxvdvvA9K42bsAv4S2fxfYOe57IJSRkZGRkZGxx7jxSHDHcRBXQMTyIjInBgHwBJ/bEx8PEANC+uhbpSSggCBAVODVabpI1S/k4WLZpTn6NpMhoX9Y40hxYERFpMcqUs4AloCtDQdID1YhnyXZ2hLjAYWiO9Dy1PDB7tPhIqLx+uMB8grZaR+Qxl2/C2RkZGRkZGRk7A7rBf7J0DR5/LUTjzUPIPSPGvQJiVJiB7kcQCiUOJrcFNtDZIf2xarQ3aGvLNxAVIFAabz90BFiBIlycTBhgWwOWCH0FLYHlPqwHaCvcIn2ZbosCevfPTRiFFcgvHukCjWwrc3GrGh1fsAof8EaUReKXkCB4/MzFNo97qLpFiKFYv/kNR5YQxQbQEofkZ2OuEOHqqT6gFTpru8CN7x/+jaZkZGRkZGRcV+x/rLUNcMMqUAscgnFocmpqkTzqymwVAPxfJ5PnIUUQOUKT04tEdWZyv3JCQSn96WS4pD97QfyW25A7NhSAbyhmVj0FEltA4vdiygBibXhoUYgykCUP7HwPTDeEqAIcHVMkZg7Zx4k0uFANs63hPQXCoRLAwdgGsr9Az7Qv7sgQGgg1aPl/BJLExBWgG4RFRLFImGmIquPC/klEGyCG0AuAXaJJC+B8FVe9NYQDEcXB8g6AQcjYJ1goJIggHWCrFR0S6kRHN5+4BzFi8NaoN35NRxUvL+JJdZr7PV4wK6fj8nIyMjIyNhr3OxdXAYq7FHZwB6bDSzSh4sF0utChqo0NAvaT1hLzXwFinmCzmeDucEQK18TTaQoFgP7bNC+RZ4OT4T6gQogDFYk+1QxQlj19QGSAWKiLYp8P0Ag1Gbz1ULfWHLg9iUnQNK5QQJcukm04blKLH2GgEJCY+HzXAZWCvHKco3Bp6MIaCjSXXRJyOxeqhnzEaF93MfFGW/O16ZvDL5TM4MJIjujz/cHypkQuuzRwWJ93BKdIt+wCRAPl9kpe2Ikkb2mFgGlxh/i40d3EHfdvoyMjIyMu43ylt/IAmGHnN5iIt7wKfbv01RAcJqFRl9lcjYQSnbQqKgC4fYOwSJt6N6trE0twZ9kN/PqNpTQeICvr4TLsDYC06U7BMjshS+v1/aT7IwQYD5LcgRQXMT2FrBfBLjZ6151jDElk9tPFfpUgk2yregusX25BJbwAFEfM+YI6vGAti4bTtizB+TjfQCrERyhKb2X8D6A9wX75P4t4neBYJeP6pdhg/gQl8MWvytzeSTjgOQBynQdh/iXKdxOrGJ/RkZGRsb9QmXihGr5+g8GGg9uTh+KoVZuNIzV+CwRucFBEyr1mVjx4irOxwM1BhirB6Q+2eNQi4eqR+aF6mELtoMzCR7V9RAFe/ZvQogNiyY8FPSUTFsLp8TeTmMui5mtw7bcaT0Yw2AA4wFRQIlkgq+1DQrNhkmoxS5Jq+u6bMAIGRECEANgXHTgWzwgBOhDH2l0oTQ4D8D5NMktBgNywAEMjo8rwATMZrPY7JGxBoJCkIBDQiAY09EGTUiBCWkUpISfGPR5AAwBfZiG2z7Ayc1yeKTxid39xBNwfHr4O0LA48ePFTvhYrF1r4tyAoz9n2MCqEuBtp/6GDR0oAYfG/R6wJExHYZHfhygsv7fEWCOj4bYmsP5A+pL4MkTfAnMlD4F+r3bobKvTyTA2P/w7PN+Agq2QW8piqMCpTBwenoKvX0AHGkGtP2YAPvTEWA7QUTAudn7/NxtOG46wWNmDtpBEkBzN7rBEvAFHp+YTB/q97qPAN4gHFqgBi8uLsC7qPCA6mg41G/+ErByPwEXDdoNxRhOx+M5jPEzQugS0ht+b1/Y3gEnYMAIAOIBE29/hIDucE8tmMsNOgK4B1RHFu4UCRlMHzv0xzcajcfdXWDs2h8TArBCkoDUJYDLmz6w7ip3BFS0ve5wTRwAn6keMA9I3QYbfSZ0DKbyt+7OXjGI1idPcfNyAyfAMlCrzaGqphYrxHocLHRJVycnfGUcbtT+jIyMjIw9x7Nn8fJSzG0TmFtO8rZT+XT3S3ub+tKJbbLd5diTVp50+zahyeHSslJ/YPrU0fuazrZO2CZ92/ZCCVXlGRiZKPJyPPRxyIFWeXLQBXJBKiq/3divEAN6ZwM200Qjm7EJBZeWm/PRWVCbYK7s7u2l4XaCz+lzgOfMfhMonXr7TWzeZb98dbgIzBT8Ub8eYYUqfZ4rVJ/MDbIDgPqTulJ/xvntWAtjIisqnwxOkGz0n077FARoY79GdA6HPE4rOy196NiMWHTZlSSApcOgXpy/fHV2joaNKu3ffsAnRcBf4K/6NcIG6tIxk3HyoXPjASqfUgXbYN5PzpL2njkR9QMjeDTVHDTCgRuxOegjoO0FvKzP/t/gmVdI24+G7NIe8JX6Wv3dDyldMA+4YB5wwTygtd+dwRqaTqrLb1l73zTSN52CNpnHuQOYPsDblybgxfkXh/oVtr+N1DEBJdhRJyd/Bd/q1z+cbNrD17iVKyajcnv9arhOkRPgsruuD6DmNPwpDNrLw2CoTgHni4yALr0L29+tiKAEIPn868ejx//8rpWP3OEOl5On9OwpcQm0MhafP/ey8f1uvDNIgGLQG8z4YO99ENgg95etwv4uYJYY8fUGHYH6j6fscHFZMftlAl9i+9XL73X3N/n+ZStOzfVfRvYXhrbdKOpEgVQTg/wsDuDD3kwOfQNMTJ5y+/ltUDWLunyxnRF46IqlBzGMY4X7inggREFioIyMjIyMHWCIB6ZNKAcXseo3vLTQTkVE7348dlwJJSz0+wLfmi8BhZqfw3D4ww/wHVLnEd5/fgYvXsDZ3MlsvYUbbnDjDZ3MN3TJG4+bxjAaDl8TBri9qxEw1ccao2wTNAMLHo2f+sjrXwb/9qHoYqgPMBXJTVfOpmrZH23y6uvo0LHSyY6fHGwKfHJlAuMFvObjDYrIqxBgQi20h7Hd/nYVLmno+eaNUm/eeH2GCuopntnhBJAlI2AHo9CCh1I1QxUdAbqqGY9BBLwyc3W4wYVhvY8A4BoIc1l5M7vnPWphZW9/Ses3n37y9a0uGqFwFQZsQQbd386DogpgEk+dzynsAZMJXq8+ns9NeukJ0PYrNATGGefJQlhkLo7DTXr+y3bNiOsDvrXTz/C2q1DXZH84iRNwrP88Nj+u2DjYEE6RBxD9Knj16ujVHC67A7422o02RwD3gB+t7EblWvu9geOFxSnd3ROmT+nJyQkhoPlsxVONc/3TEdBos+jtA+ZzcwHgTvD1cDjaYCcItA8w9i88A8b+mqSjc6Pvqd998QguEQPmQMeo23ODN86+p0/bn1buBkT6+oBhNZ/PYY4ZAHYb3PRd4LkZmPX68NRtMZn4ASvdA+qf0jMA5MP9eeg28Nug9QiLnj5A33U1MAES6xHAUNpz/9zFAYE1gqQDMT3G6xI9pwdw/aIgKoHCS1YGlRnSq9yCjdXjgN3j+N27YyROHxmuNAeNKPpYuXIyIyMjYy0M8eros59MF/PT2c602T7eA7zvhJ9dr/vzDjXaLp4Yc5+0wllzxzHv3gdmMMM7/CcQzKgVBqYTmFn+Z+mKm8J7k0A5F/jgCfjQ1WBhQyiOqD0lYuqBb+AyzMw9Ha2G3m6c8qQx+AlqnIceQp+Sb6i9UyQWbhr54+AjnZ0VzW2TAN0DmBT6PWmc6jDBE2PK2u+nF43dyP7Q0t1pOcX2fdRvH0mF2Q4JqN35rnHjVIeaXfIAVyUuw/aHCCiJy9iF5l1621zweI8KZrPZ9iJdb7DXJ3US0OSrtZ10imt7wHY7QesAzUMz1oZ3noB3qFJ/H18j97FYuw8QDN4oeKf30osvcSW2ExLo+VcbuAuo/sUIm8fMG9xocO3Ea19J9gFYivnHJ2KnyfovZlgW3v6ySx32abQiIyMjIyPjhlFDTLxpwIgFMnTp6A3g4IDKNY+stkwAMAoIAbasxBXqUWneSAWTMjt50lTqT29rFjvXohjsDNm2YPXDFlICmrJOZ3t6tHm8AiEAl0sCeLIIorIRt+cFbew/QRsoAXb4o1XSfoywzm0FTMAoYBNvLyFu8v8HpLBtD1iKgC17wHb7AI6d9wFbvguAIGTHd4E9wG7jgIyMjIyM+434c2R3HeV/Ffx6jtZu6ijl8h59T655jhR+rdHzDOP6beABCheb8O8/WFXeOyzgf5oAhVYnKxP7CwaAf1afJu8bSrhS6tdaXeGnrRenOqOlz9d6QwYnA/3TLd+GE7qe3chA5YF5DfY0vK3adfOX/gyNp2BW25MHdxAB9qvRiiP3/XpQQFGYDU4+Mi///XumXG8pjvaUAOsBGlf4jJt+YYEzeEzAdw06F19R3juM7D1wita86GR0CKfDHgLuXCc4Bri6vMLdfjMc4VNSUNsdodo2xu/1+Xl/K5+az8jIyMhYG/z5gJTMF1GtKq/a3rpyCvz5gJTMl9GtKq/a3rpyCmfQ4WwZmS+kXFVetb115ST48wEf/AGcfG1iw+tWbpbS2vJ3nQxcVr3lH3z5h972FUTLzYpOVk7l5hD+eYcYwDcAnewOotrZ4OtrPDucqi/LRX0/RR4qx7Nn4U8g+qjffvuN6Gf+nC85vwauHjaYyubqvWYKY4VEfSUMitdnBCT1Ue63R5439m+OgCn6DroAAaHPVQxKth/wkJgHmG8bmQMsT0D6EjDfvhVRKO3ywOQUgRA7nmL1uawZmHf1k+DPBwQ6NdcJ+k6Md1LA5f5ONdhJ8vZ5J0vLHT99srkGOjmJbd/G1r2Nriqnse1AZt1AalU5jW2HsuuG0qvKGRkZGRkZGRG0gcONyXsP9v8D0/IdJADiBNiXl3327WRGgOL/9HC/0XwlIURkRhC4tz6Z/fu7fUf2gHvfB9z3u0BGRkZGRkbGplHcnkgguQoSqtUXuhbs/wPtMwqV0HUJAvj5vk32b8IDuL23yn7qAXZ5u32hbRX7d3o82Df1FZXvbh9QOfhyxldr/+3xgXU9oKmvsHyr7F/XA269/eveBXrsv7N9QALe/tvjA0kPWAXGbvebkbHn+D/J5nMcHzx1UAAAAABJRU5ErkJggg==) !important}.admin-color-sunrise .ui-datepicker-header{background-color:#b43c38 !important;color:white !important}.admin-color-sunrise .ui-datepicker td .ui-state-active{background-color:#df8a48 !important;color:white !important}.admin-color-sunrise .ui-datepicker td .ui-state-hover{color:#df8a48 !important}.admin-color-sunrise .ui-datepicker td .ui-state-highlight{background:#dd823b !important;border:1px solid #b43c38 !important;color:white !important}.admin-color-sunrise .redux-container-switch .cb-disable,.admin-color-sunrise .redux-container-switch .cb-enable,.admin-color-sunrise .ui-state-default,.admin-color-sunrise .ui-widget-content .ui-state-default,.admin-color-sunrise .ui-widget-header .ui-state-default{background-color:#f5f5f5 !important;background-image:-khtml-gradient(linear, left top, left bottom, from(#f8f8f8), to(#f5f5f5)) !important;background-image:-moz-linear-gradient(top, #f8f8f8, #f5f5f5) !important;background-image:-ms-linear-gradient(top, #f8f8f8, #f5f5f5) !important;background-image:-webkit-gradient(linear, left top, left bottom, color-stop(0%, #f8f8f8), color-stop(100%, #f5f5f5)) !important;background-image:-webkit-linear-gradient(top, #f8f8f8, #f5f5f5) !important;background-image:-o-linear-gradient(top, #f8f8f8, #f5f5f5) !important;background-image:-linear-gradient(top, #f8f8f8, #f5f5f5) !important;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#f8f8f8', endColorstr='#f5f5f5', GradientType=0) !important;border-color:#ccc !important}.admin-color-sunrise .ui-datepicker td .ui-state-active{color:black !important;font-weight:700 !important;background:white !important}.admin-color-sunrise .redux-container-switch .cb-disable.selected{background-color:#646464 !important;background-image:-khtml-gradient(linear, left top, left bottom, from(#929292), to(#646464)) !important;background-image:-moz-linear-gradient(top, #929292, #646464) !important;background-image:-ms-linear-gradient(top, #929292, #646464) !important;background-image:-webkit-gradient(linear, left top, left bottom, color-stop(0%, #929292), color-stop(100%, #646464)) !important;background-image:-webkit-linear-gradient(top, #929292, #646464) !important;background-image:-o-linear-gradient(top, #929292, #646464) !important;background-image:-linear-gradient(top, #929292, #646464) !important;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#929292', endColorstr='#646464', GradientType=0) !important;border-color:#767676 !important}.admin-color-sunrise .redux-container-switch .cb-enable.selected,.admin-color-sunrise .redux-field-container .ui-buttonset .ui-state-active{background-color:#dd823b !important;background-image:-khtml-gradient(linear, left top, left bottom, from(#e29559), to(#dd823b)) !important;background-image:-moz-linear-gradient(top, #e29559, #dd823b) !important;background-image:-ms-linear-gradient(top, #e29559, #dd823b) !important;background-image:-webkit-gradient(linear, left top, left bottom, color-stop(0%, #e29559), color-stop(100%, #dd823b)) !important;background-image:-webkit-linear-gradient(top, #e29559, #dd823b) !important;background-image:-o-linear-gradient(top, #e29559, #dd823b) !important;background-image:-linear-gradient(top, #e29559, #dd823b) !important;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#e29559', endColorstr='#dd823b', GradientType=0) !important;border-color:#ad5d1e !important;border-color:#c36922 !important;-webkit-box-shadow:inset 0 1px 0 #e8ac7c,0 1px 0 rgba(0,0,0,0.15) !important;box-shadow:inset 0 1px 0 #e8ac7c,0 1px 0 rgba(0,0,0,0.15) !important}.admin-color-sunrise #redux-header{background:#b43c38;border-color:#dd823b}.admin-color-sunrise #redux-header .display_header span{color:#f0c8c6}.admin-color-sunrise .redux-sidebar .redux-group-menu li.active.hasSubSections a{position:relative}.admin-color-sunrise .redux-sidebar .redux-group-menu li.active.hasSubSections a:after{right:0;border:solid 8px transparent;content:"\0020";height:0;width:0;position:absolute;pointer-events:none;border-right-color:#fff;top:50%;margin-top:-8px}.admin-color-sunrise .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li a:after{border:0 none !important;content:"\0020" !important}.admin-color-sunrise .redux-sidebar .redux-group-menu li.hasSubSections .redux-menu-error{display:none;margin-right:5px}.admin-color-sunrise .redux-sidebar .redux-group-menu li.hasSubSections a.hasError .extraIconSubsections{background-color:#b94a48;color:#f2dede}.admin-color-sunrise .redux-sidebar .redux-group-menu li.hasSubSections a .extraIconSubsections{border-radius:10px;-moz-border-radius:10px;-webkit-border-radius:10px;border:0 solid transparent;float:right;font-size:9px;height:9px;line-height:9px;margin-right:5px;padding:6px 7px 4px 7px;width:5px}.admin-color-sunrise .redux-sidebar .redux-group-menu li.active a .extraIconSubsections,.admin-color-sunrise .redux-sidebar .redux-group-menu li.activeChild a .extraIconSubsections{display:none}.admin-color-sunrise .redux-sidebar .redux-group-menu li.active.hasSubSections .redux-menu-error,.admin-color-sunrise .redux-sidebar .redux-group-menu li.activeChild.hasSubSections .redux-menu-error{display:block}.admin-color-sunrise .redux-sidebar .redux-group-menu li.active.hasSubSections .subsection .redux-menu-error,.admin-color-sunrise .redux-sidebar .redux-group-menu li.activeChild.hasSubSections .subsection .redux-menu-error{margin-right:2px}.admin-color-sunrise .redux-sidebar .redux-group-menu li.active,.admin-color-sunrise .redux-sidebar .redux-group-menu li.activeChild{border-left:0 none}.admin-color-sunrise .redux-sidebar .redux-group-menu li.active a,.admin-color-sunrise .redux-sidebar .redux-group-menu li.activeChild a{color:#b43c38}.admin-color-sunrise .redux-sidebar .redux-group-menu li.active.hasSubSections .active a:after,.admin-color-sunrise .redux-sidebar .redux-group-menu li.activeChild.hasSubSections .active a:after{right:0;border:solid 8px transparent;content:"\0020";height:0;width:0;position:absolute;pointer-events:none;border-right-color:#fff;top:50%;margin-top:-8px}.admin-color-sunrise .redux-sidebar .redux-group-menu li.active.hasSubSections a,.admin-color-sunrise .redux-sidebar .redux-group-menu li.activeChild.hasSubSections a{-webkit-transition:all 0.2s;-moz-transition:all 0.2s;transition:all 0.2s;color:#fff;width:auto;border-bottom:0}.admin-color-sunrise .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li,.admin-color-sunrise .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li{border-top:0 none !important}.admin-color-sunrise .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li.active a:hover,.admin-color-sunrise .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li.active a:hover{color:#fff}.admin-color-sunrise .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li a,.admin-color-sunrise .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li a{width:auto;border-top:0 !important;padding:7px;color:#fff;padding-left:15px;-webkit-transition:all 0.2;-moz-transition:all 0.2;-ms-transition:all 0.2;-o-transition:all 0.2;transition:all 0.2}.admin-color-sunrise .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li a:hover,.admin-color-sunrise .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li a:hover{color:#cc6c23;background:#8d2f2c}.admin-color-sunrise .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li a span.group_title,.admin-color-sunrise .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li a span.group_title{padding-left:5px !important}.admin-color-sunrise .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li.hasIcon a,.admin-color-sunrise .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li.hasIcon a{padding-left:14px}.admin-color-sunrise .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li.hasIcon a span.group_title,.admin-color-sunrise .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li.hasIcon a span.group_title{padding-left:30px !important}.admin-color-sunrise .redux-sidebar .redux-group-menu li.active.hasSubSections a{background:#dd823b}.admin-color-sunrise .redux-sidebar .redux-group-menu li.active.hasSubSections ul.subsection li a{background:#b43c38}.admin-color-sunrise .redux-sidebar .redux-group-menu li.activeChild.hasSubSections a{background:#f0c8c6;text-shadow:1px 1px #d0534d}.admin-color-sunrise .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li a{background:#b43c38;text-shadow:none}.admin-color-sunrise .redux-sidebar .redux-group-menu li.activeChild.hasSubSections ul.subsection li.active a{background:#dd823b;text-shadow:1px 1px #98511a}.admin-color-sunrise .redux-container-image_select .redux-image-select-selected img{border-color:#dd823b}.admin-color-sunrise #redux-footer #redux-share a{color:#dd823b}.admin-color-sunrise #redux-footer #redux-share a:hover{color:#98511a}.admin-color-sunrise .select2-results .select2-highlighted{background:#dd823b}.admin-color-sunrise .select2-drop-active,.admin-color-sunrise .select2-container-multi.select2-container-active .select2-choices,.admin-color-sunrise .select2-drop.select2-drop-above.select2-drop-active,.admin-color-sunrise .select2-container-active .select2-choice,.admin-color-sunrise .select2-container-active .select2-choices,.admin-color-sunrise .select2-dropdown-open.select2-drop-above .select2-choice,.admin-color-sunrise .select2-dropdown-open.select2-drop-above .select2-choices{border-color:#dd823b}.admin-color-sunrise .select2-dropdown-open.select2-drop-above .select2-choice,.admin-color-sunrise .select2-dropdown-open.select2-drop-above .select2-choices{border-top:inherit}.admin-color-sunrise .noUi-connect{background-color:#df8a48 !important;background-image:-khtml-gradient(linear, left top, left bottom, from(#e59e66), to(#df8a48)) !important;background-image:-moz-linear-gradient(top, #e59e66, #df8a48) !important;background-image:-ms-linear-gradient(top, #e59e66, #df8a48) !important;background-image:-webkit-gradient(linear, left top, left bottom, color-stop(0%, #e59e66), color-stop(100%, #df8a48)) !important;background-image:-webkit-linear-gradient(top, #e59e66, #df8a48) !important;background-image:-o-linear-gradient(top, #e59e66, #df8a48) !important;background-image:-linear-gradient(top, #e59e66, #df8a48) !important;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#e59e66', endColorstr='#df8a48', GradientType=0) !important}@media screen and (max-width: 600px){.redux-group-tab-link-a{min-height:15px}.redux-group-tab-link-a span{padding:11px 12px;color:#555;-webkit-transition:all 0.3s;-moz-transition:all 0.3s;transition:all 0.3s;text-shadow:none !important}.redux-group-tab-link-a span:hover{background:#e5e5e5}}@media screen and (max-width: 782px){#redux-footer #redux-share{line-height:38px;font-size:18px}.sticky-save-warn .redux-save-warn{right:13px;top:46px}.redux-container .expand_options{margin-top:5px}.redux-action_bar input{margin-bottom:0 !important}}@media screen and (max-width: 600px){#redux-footer #redux-share,.redux-hint-qtip{display:none}.redux-container .redux-action_bar{float:none}}.redux-sidebar .icon-large,.redux-main .icon-large{background-image:inherit !important;width:inherit;height:inherit}.redux-main dd,.redux-main li,.redux-sidebar li{margin-bottom:0 !important}.fully-expanded .redux-sidebar{margin-left:-500px}.fully-expanded .redux-main{margin-left:0}.fully-expanded .redux-group-tab{display:block}@media screen and (max-width: 640px){#redux-defaults-section{display:none}}@media screen and (max-width: 730px){#redux-share{display:none}}@media screen and (max-width: 730px){#redux-defaults-section2{display:none}#redux-share{display:none}}@media screen and (max-width: 600px){.form-table>tbody>tr>th{padding-bottom:0 !important}.redux_field_th{padding-top:0;padding-bottom:0}.redux-main .redux-field-container{padding-top:0;padding-bottom:0}.redux-main .subsection a{min-height:15px}}@media screen and (min-width: 601px) and (max-width: 782px){.redux-container .sticky-save-warn .redux-save-warn{top:47px !important;right:13px !important}}@media screen and (max-width: 782px){.redux-main .form-table-section-indented input[type=text]{width:95% !important}.redux-main .redux-container-sortable input[type=text]{width:80%;display:initial}.redux-main .redux-typography-container .input_wrapper input.mini{font-size:16px !important;height:40px !important;padding:7px 10px !important;line-height:24px !important}.redux-main .redux-typography-container .picker-wrapper label{margin-top:16px !important}.redux-main .input-append{height:50px !important}.redux-main .input-append .add-on{font-size:16px;line-height:24px !important;padding:7px;height:32px !important;float:right;margin-top:-40px}.redux-main .redux-hint-qtip{float:left !important}.redux-main .redux-action_bar .button{margin-top:-1px}}@media screen and (max-width: 600px){.sticky-save-warn .redux-save-warn{top:0 !important;right:14px !important}}@media screen and (max-width: 570px){.redux-main .redux-container-sortable .checkbox-container{width:85%;padding-bottom:5px}.redux-main .redux-container-sortable .checkbox-container label{display:initial}}#redux-header{position:relative}.redux-main{position:relative}.redux-main #redux-sticky{min-height:32px;margin-left:-20px;margin-right:-20px;margin-top:-10px;margin-bottom:8px}.redux-main #redux-sticky #info_bar{height:32px}.redux-main #redux-sticky #info_bar .expand_options{margin-top:4px}.redux-main .redux_field_search{top:50px;right:5px}.redux-main #redux-footer-sticky{margin-left:-20px;margin-right:-20px;margin-bottom:-10px}.redux-qtip{z-index:999999 !important}.redux-main pre{white-space:pre-wrap;white-space:-moz-pre-wrap;white-space:-pre-wrap;white-space:-o-pre-wrap;word-wrap:break-word} diff --git a/library/admin/ReduxCore/assets/css/redux-admin.scss b/library/admin/ReduxCore/assets/css/redux-admin.scss deleted file mode 100644 index a8bdc71d..00000000 --- a/library/admin/ReduxCore/assets/css/redux-admin.scss +++ /dev/null @@ -1,1517 +0,0 @@ -.spinner { - visibility: hidden; - display: block; -} -.spinner.is-active{ - visibility: visible; -} - -.redux-main .description { - margin-top: 7px; -} - -.form-table > tbody > tr > th { - width: 30% -} - -.redux-container { - //font-family: "Open Sans","Lucida Grande", Sans-serif; - background-color: #f5f5f5; /* Old browsers */ - background-repeat: repeat-x; /* Repeat the gradient */ - background-image: -moz-linear-gradient(top, #f2f2f2 0%, #f5f5f5 100%); /* FF3.6+ */ - background-image: -webkit-gradient(linear, left top, left bottom, color-stop(0%, #f2f2f2), color-stop(100%, #f5f5f5)); /* Chrome,Safari4+ */ - background-image: -webkit-linear-gradient(top, #f2f2f2 0%, #f5f5f5 100%); /* Chrome 10+,Safari 5.1+ */ - background-image: -ms-linear-gradient(top, #f2f2f2 0%, #f5f5f5 100%); /* IE10+ */ - background-image: -o-linear-gradient(top, #f2f2f2 0%, #f5f5f5 100%); /* Opera 11.10+ */ - filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#f5f5f5', endColorstr='#eeeeee', GradientType=0); /* IE6-9 */ - background-image: -linear-gradient(top, #f2f2f2 0%, #f5f5f5 100%); /* W3C */ - border: 1px solid #dedede; - -webkit-box-shadow: 0 1px 1px rgba(0, 0, 0, .04); - box-shadow: 0 1px 1px rgba(0, 0, 0, .04); - -moz-box-shadow: 0 1px 5px rgba(0, 0, 0, 0.4); - margin-top: 5px; - overflow: hidden; - - a { - &:focus { - box-shadow: none; - } - } - - #redux-header, - #redux-footer { - text-align: right; - padding: 6px 10px; - } - - #redux-header { - background: #f1f1f1; - border-bottom: 3px solid blue; - - .display_header { - float: left; - margin: 20px 10px; - - h2 { - display: inline-block; - font-style: normal; - padding-right: 5px; - } - - .redux-dev-mode-notice-container { - position: absolute; - top: 67px; - left: 20px; - bottom: auto; - width: auto; - } - - span { - color: #888; - - &.redux-dev-mode-notice { - //position: absolute; - background-color: #f0ad4e; - display: inline; - padding: .2em .5em .2em; - font-weight: 700; - line-height: 1; - color: #fff !important; - text-align: center; - white-space: nowrap; - vertical-align: baseline; - border-radius: .25em; - } - } - } - - .icon32 { - float: right; - margin: 16px 16px 0; - } - } - - #redux-footer { - border-top: 1px solid #E7E7E7; - z-index: 999; - - #redux-share { - float: left; - line-height: 28px; - font-size: 15px; - - a { - text-decoration: none; - margin-right: 10px; - - img { - margin-bottom: -3px; - } - } - } - } - - .notice-green { - margin: 0; - border-bottom: 1px solid #E7E7E7; - background-color: #DFF0D8; - color: #468847; - padding: 8px 35px 8px 14px; - text-shadow: 0 1px 0 rgba(255, 255, 255, 0.5); - } - - .notice-blue { - margin: 0; - border-bottom: 1px solid #BCE8F1; - background-color: #D9EDF7; - color: #3A87AD; - padding: 8px 35px 8px 14px; - text-shadow: 0 1px 0 rgba(255, 255, 255, 0.5); - } - - .notice-yellow { - margin: 0; - border-bottom: 1px solid #E7E7E7; - background-color: #FCF8E3; - color: #C09853; - padding: 8px 35px 8px 14px; - text-shadow: 0 1px 0 rgba(255, 255, 255, 0.5); - } - - .notice-red, - .redux-field-errors { - margin: 0; - border-bottom: 1px solid #E7E7E7; - background-color: #F2DEDE; - color: #B94A48; - padding: 8px 35px 8px 14px; - text-shadow: 0 1px 0 rgba(255, 255, 255, 0.5); - } - - .redux-field-error { - input, textarea, checkbox { - background-color: #FFF6F6; - color: #A00; - } - - } - .redux-field-warning { - input, textarea, checkbox { - background-color: #fcf8e3; - color: #444; - } - } - - .redux-field-errors, - .redux-field-warnings, - .redux-save-warn { - display: none; - } - - .sticky-save-warn { - min-height: 76px; - - .redux-save-warn { - position: fixed; - top: 32px; - right: 21px; - left: 183px; - opacity: 1; - z-index: 9999; - } - } - - #info_bar { - background: #f3f3f3; - border-bottom: 1px solid #dedede; - padding: 6px 10px 6px 6px; - text-align: right; - -moz-box-shadow: inset 0 1px 0 #fcfcfc; - -webkit-box-shadow: inset 0 1px 0 #fcfcfc; - box-shadow: inset 0 1px 0 #fcfcfc; - } - - .redux-group-tab { - display: none; - margin-bottom: 15px; - - .redux-theme-data { - padding: 20px 0; - border-top: 1px solid #E7E7E7; - - &.theme-description { - padding: 10px 0; - border-width: 0; - } - - &.theme-uri, - &.theme-author, - &.theme-version { - padding: 0; - border-width: 0; - } - } - - h3 { - margin-top: 0; - line-height: 2em; - border-bottom: 1px solid #E7E7E7; - } - - .redux-section-desc { - margin-bottom: 15px; - color: #666; - } - } - - .redux-action_bar { - float: right; - .spinner { - float: left; - margin-top: 4px; - } - } - - .redux-ajax-loading { - display: none; - background: red url(data:image/gif;base64,R0lGODlhEAAQAPUAAIiIiIqKio2NjZSUlJqamp6enqKioqSkpK+vr7i4uL+/v8PDw8XFxcnJyc/Pz9HR0dTU1NjY2Nzc3OLi4ubm5unp6ezs7PPz88vLy83NzdDQ0NXV1d3d3eHh4bu7u8zMzOvr6+3t7ZiYmNbW1sDAwMTExNra2s7OztPT09vb2+Xl5QAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAACH/C05FVFNDQVBFMi4wAwEAAAAh/i1NYWRlIGJ5IEtyYXNpbWlyYSBOZWpjaGV2YSAod3d3LmxvYWRpbmZvLm5ldCkAIfkEAAoA/wAsAAAAABAAEAAABXDgJY6XZZEoOTnOlI5WdUFNA5UnSR3FJNUSieFAIUUEgcdl4noEBBGSZaHIiSqKhTX2GhVFiQGjuxgkSoYAoosAGE6RhKQrUURHlS+pItMVCHMjEgQ9JBJISg+JT3ciFg4NFkcCNw0OViiDgF0oTC8hACH5BAAKAP8ALAAAAAAQABAAAAVx4CWOZGle1qJYp2hV1xYE29V1JXUYHWUcnQgGwyFFBAENiqUZ1kapFamTyeBcsNOLMkoMGC3GIIEyBBAtRMDAiiSKp04iQqpwc9kRpUCAizgEBVciEQNJFxpKGgECdFAYYBsCAjUMGS0XgAODmDacIyEAIfkEAAoA/wAsAAAAABAAEAAABnbAi3BILBovIMUidBSGQJdNIKBBMomUg6FDMRgoHcOBQowIqNaLJiCIEEMLxdWpnIfITRAHnxgwjiEfDR8UIQYBCEcgDYwdUR6ORxEfG3MgeFiFRB0FBBxEHAQFkUJmaBofamxuRB9/GwICGxeMTRehnrabpERBACH5BAAKAP8ALAAAAAAQABAAAAZ9wItwSCwaL5aFwnIUWiqXUSAwulSYRMrB0KEYDJSO4UAhRgQBDZLpCAgixOSSWFEssEho81IWJgYMTQwDCUgGAQhNCAEGTCMJHU0dCXBDFX1DFhwdeHwFIhxmGBihQxEDaRcOGhYao1WZGIFnAiMUDg6YRR0ioE57Fx2RRkEAIfkEAAoA/wAsAAAAABAAEAAABXLgJY5kaV7WolinaLGQEEBXxZLUUUyUYVATw4FCisg0NZYmIIiQUosKqaJY3FDS1oUoSgwYrcUggTIAEC1EwMCKJCatSYI2qnBx2dGkQOCQOAQFdxdGARoVGhCITE4kGBgWEI8QFgwYWhGTWiMWERFXIyEAIfkEAAoA/wAsAAAAABAAEAAABn/Ai3BILBovloXCchRaKpdRIDC6VJhEysHQoRgMlI7hQCFGBAENkukICCLE5JJYUSywSGjzUhYmBgxNDAMJSAYBCE0IAAZMEQkdTRwKVUMcHHhCFXpDERgYcJYEBZFDI58aFhoOFxpuoUIUGhoUZwJVGA6ZaxccBAQce0QdpUVBACH5BAAKAP8ALAAAAAAQABAAAAZ8wItwSCwaLyEFKXQUhioXSCAAuVSYRMrB0KEYDJSO4UAhmgQBDZKpCQhMxFBJgRVWlFkOtElhUj4NH3VEJQMJFx0NintFCAEGISEQH3BHHR5VThVlRRSMQh0FBBxEHAQFnEJnaRcfHxdtb0WKIWcCVSUNTYgEo7tEHR1HQQAh+QQACgD/ACwAAAAAEAAQAAAGdcCLcEgsGi8hhSJ0FHY6l1EgMLqAmEROo5HqGAwqL5g42qKsoAsqIEgRVacTdAhSLLBI1bWpwiYGDE0MAwlIBgEITQgBBkwjCRxNHQlVdCpGekUqBQSRQxwEBZdDKQIBZ3FqbG5EDYEjpikhW3hFoJ1NRU9HQQA7) no-repeat; - width: 16px; - height: 16px; - margin: 3px 4px 0; - float: right; - } - - #redux-intro-text { - background: #f3f3f3; - border-bottom: 1px solid #dedede; - -moz-box-shadow: inset 0 1px 0 #fcfcfc; - -webkit-box-shadow: inset 0 1px 0 #fcfcfc; - box-shadow: inset 0 1px 0 #fcfcfc; - padding: 3px; - padding: 10px 10px; - - p { - margin: 0; - font-family: "Lucida Grande", Sans-serif; - color: #888; - } - } - - .expand_options { - cursor: pointer; - display: block; - height: 22px; - width: 21px; - float: left; - font-size: 0; - text-indent: -9999px; - margin: 1px 0 0 5px; - border: 1px solid #bbb; - -webkit-border-radius: 2px; - -moz-border-radius: 2px; - border-radius: 2px; - background: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABkAAAAyCAIAAAAm4OfBAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAQhJREFUeNrslT0KhDAQhTeLR7ATT6IXSKGFYO0lciFrO1N4AU8TLNXKv0CaJbLJRAZxl1hYyJuXN+PoR/Z9fyFdBNNr27Zf8Oq6bhgGSGUYhpTSzyeBNi8hRFVVEK+6rrXaQFOs6yrvTdOYjcqyVEpTLqXI89yaSypBudq2xckF2TipOSvfmmhZFuAGnJV6Licvey5gj7fnwpwXvEfLfqnT0jQ1OBJCQLnUBvZ9b85VFAV076UU8g1ZckVRxBiDzD6OY62WzPOM9i+cpunvvcZxfCQfPWs9a91Ym2UZ5xyHtd/e8hXWng+/zlrD9jmz1tDj7bkw5wXv0Y210itJEs9az9oHsPYQYACveK0/IuB51AAAAABJRU5ErkJggg==) no-repeat -2px -26px; - - &.expanded { - background: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABkAAAAyCAIAAAAm4OfBAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAQhJREFUeNrslT0KhDAQhTeLR7ATT6IXSKGFYO0lciFrO1N4AU8TLNXKv0CaJbLJRAZxl1hYyJuXN+PoR/Z9fyFdBNNr27Zf8Oq6bhgGSGUYhpTSzyeBNi8hRFVVEK+6rrXaQFOs6yrvTdOYjcqyVEpTLqXI89yaSypBudq2xckF2TipOSvfmmhZFuAGnJV6Licvey5gj7fnwpwXvEfLfqnT0jQ1OBJCQLnUBvZ9b85VFAV076UU8g1ZckVRxBiDzD6OY62WzPOM9i+cpunvvcZxfCQfPWs9a91Ym2UZ5xyHtd/e8hXWng+/zlrD9jmz1tDj7bkw5wXv0Y210itJEs9az9oHsPYQYACveK0/IuB51AAAAABJRU5ErkJggg==) no-repeat -2px -1px - } - - &:hover { - border-color: #888; - } - } - - .sticky-footer-fixed { - background: #f3f3f3; - border-top: 1px solid #dedede !important; - -moz-box-shadow: inset 0 1px 0 #fcfcfc; - -webkit-box-shadow: inset 0 1px 0 #fcfcfc; - box-shadow: inset 0 1px 0 #fcfcfc; - } - - .redux-sidebar, - .redux-main { - min-height: 300px; - - } -} - -/* redux-container */ - -.no-js { - border: 1px solid #ffbaba; - margin: 0; - border-bottom: 1px solid #E7E7E7; - background-color: #F2DEDE; - color: #B94A48; - padding: 8px 35px 8px 14px; - text-shadow: 0 1px 0 rgba(255, 255, 255, 0.5); -} - -.redux-main { - background: #FCFCFC; - margin-left: 201px; - border-left: 1px solid #D8D8D8; - padding: 10px 20px; - -moz-box-shadow: inset 0 1px 0 #fff; - -webkit-box-shadow: inset 0 1px 0 #FFF; - box-shadow: inset 0 1px 0 #FFF; - position: relative; - #redux_ajax_overlay { - position: absolute; - top: 0; - left: 0; - right: 0; - bottom: 0; - -moz-opacity: 0.10; - -khtml-opacity: 0.10; - opacity: 0.10; - filter: progid:DXImageTransform.Microsoft.Alpha(opacity=10); - filter: alpha(opacity=10); - background: #000; - z-index: 200; - display: none; - } - .form-table.no-border { - border-top: none; - } - .form-table tr { - border-bottom: 1px solid #E7E7E7; - &:last-child { - border-bottom: none !important; - } - th, - td { - color: #333; - } - } - - .form-table tr td { - table.mceLayout, - table.mceLayout tr, - table.mceLayout tr td { - padding: 0; - border-width: 0; - } - - .redux-th-warning { - font-size: 1em; - color: #C09853; - font-weight: normal; - display: block; - margin-top: 10px; - } - - .redux-field-warning { - border-color: #C09853; - margin-top: 10px; - } - - .redux-th-error { - font-size: 1em; - color: #B94A48; - font-weight: normal; - display: block; - margin-top: 10px; - } - } - - input.large-text { - width: 100%; - } - - .hide { - display: none; - } - - .redux-field-container { - padding: 20px 0; - } - - .mini, - input[type=text].mini { - width: 60px; - text-align: center; - } - - input { - line-height: 19px; - } - - img { - max-width: 100%; - height: auto; - width: auto !important; - } - - .select2-default { - width: auto !important; - } - - .showDefaults { - display: block; - font-weight: normal; - font-size: .8em; - color: #888; - } - - span.description { - display: block; - font-style: normal; - font-weight: 400; - } - - #redux-system-info textarea { - min-height: 730px; - width: 100%; - } - - .field-desc { - clear: both; - font-size: 13px; - } - - .data-full li { - width: 100%; - } - - .data-half li { - width: 50%; - float: left; - } - - .data-third li { - width: 33.3%; - float: left; - } - - .data-quarter li { - width: 25%; - float: left; - } - - .ui-helper-hidden-accessible { - top: inherit; - } - - .form-table:first-child > tr th, .redux-main .form-table:first-child > tr td { - //padding-top: 0 !important; - } - - .form-table { - clear: none; - margin-top: 0px !important; - - &:first-child tr th, - &:first-child tr td { - // padding-top: 0 !important; - } - - tr:first-child th, - tr:first-child td { - padding-top: 0; - } - } - - .input-append input { - border-right: 0; - margin-bottom: 0; - border-top-right-radius: 0; - border-bottom-right-radius: 0; - margin-right: 0; - float: left; - margin-top: 0; - display: block; - } - .input-append .add-on { - border-top-right-radius: 3px; - border-bottom-right-radius: 3px; - margin-left: -2px; - padding-top: 4px !important; - padding-bottom: 2px !important; - //float: left; - } - .input-prepend input { - border-left: 0; - margin-bottom: 0; - border-top-left-radius: 0; - border-bottom-left-radius: 0; - margin-left: 0; - padding-top: 2px; - padding-bottom: 5px; - float: left; - margin-top: 0; - display: block; - } - .input-prepend .add-on { - border-top-left-radius: 3px; - border-bottom-left-radius: 3px; - float: left; - } - - .input-append { - margin-right: 10px; - font-size: 0; - white-space: nowrap; - float: left; - display: inline-block; - margin-bottom: 6px; - } - .input-append .add-on, .input-prepend .add-on { - width: auto; - display: inline-block; - min-width: 16px; - padding: 3px 4px; - font-size: 12px; - font-weight: 400; - line-height: 20px; - text-align: center; - text-shadow: 0 1px 0 #ffffff; - background-color: #eeeeee; - border: 1px solid #cccccc; - } - .input-prepend { - font-size: 0; - white-space: nowrap; - float: left; - display: inline-block; - margin-bottom: 6px; - } -} - -/* main */ - -.redux-sidebar { - width: 202px; - float: left; - - .redux-group-menu { - margin-top: 0 !important; - li { - margin-top: 0; - - &.active a, - &.active a:hover, - &.activeChild a, - &.activeChild a:hover { - background: #FCFCFC; - color: #269ad6; - width: 184px; - opacity: 1; - //margin-right:-2px; - } - - &.active a li a { - background: #333; - padding-left: 5px; - } - - &.divide { - padding: 0; - border-width: 1px 0; - border-style: solid; - border-bottom-color: #E7E7E7; - border-top-color: #F9F9F9; - } - a:first-child { - border-top: none; - } - a { - display: block; - padding: 10px 4px 10px 14px; - background: #e0e0e0; - background: transparent; - border-width: 1px 0; - border-style: solid; - border-bottom-color: #E7E7E7; - border-top-color: #F9F9F9; - opacity: 0.7; - color: #555; - font-weight: bold; - text-decoration: none; - -webkit-transition: none; - transition: none; - &.custom-tab { - background: #f6f6f6; - } - img { - width: 16px; - height: 16px; - // vertical-align:middle; - // margin-bottom:-3px; - // margin-right: 3px; - position: absolute; - left: 15px; - } - &:hover { - background: #e5e5e5; - //width: 184px - color: #777; - //margin-right: -2px; - opacity: 1; - } - } - } - } - - .redux-menu-warning, - .redux-menu-error, - .hasSubSections .extraIconSubsections { - display: inline-block; - float: right; - padding: 6px 7px 4px 7px; - margin-left: 4px; - font-family: sans-serif; - font-size: 9px; - font-weight: bold; - line-height: 9px; - border-radius: 10px; - -moz-border-radius: 10px; - -webkit-border-radius: 10px; - border: 0 solid transparent; - //margin-right: 5px; - - i { - margin-left: -3px; - margin-top: -3px; - } - } - .redux-menu-error { - background-color: rgb(185, 74, 72); - color: rgb(242, 222, 222); - } - .redux-menu-warning { - background-color: #C09853; - color: #FCF8E3; - } - - ul { - .subsection { - display: none; - } - } - - .redux-group-tab-link-a { - position: relative; - outline: 0; - i { - vertical-align: middle; - font-size: 1.35em; - position: absolute; - } - span { - display: block; - &.group_title { - padding-left: 30px; - } - } - } - - .redux-group-tab-link-li a.hasError span.group_title { - padding-right: 25px; - } - - #redux-header { - text-align: center; - - .display_header { - float: none; - } - } -} - -/* sidebar */ - -.form-table th, -.form-table td { - margin: 0; - padding: 0; - width: auto; -} - -.redux_field_th { - font-weight: bold; - // width: 30%; - padding: 20px 10px 20px 0px; - display: block; - span:first-child { - font-weight: normal; - display: block; - color: #666; - } -} - -/* - * - * NHP_Options_color - * - */ -.farb-popup-wrapper { - position: relative; - display: block; -} - -.farb-popup { - position: absolute; - left: 40px; - top: 40px; - background-color: white; - border: 1px solid #222; - padding: 5px; - z-index: 100; -} - -#ui-datepicker-div { - display: none; -} - -.mp6 { - .icon-themes { - display: none; - } - - .redux-container { - #info_bar { - padding: 6px 10px 6px 6px; - - a { - margin-top: 2px; - } - } - } -} - -.redux-timer { - text-align: center; - font-size: 10px; - color: #888; -} - -.wrap { - margin-top: 0; -} - -@media screen and (max-width: 600px) { - .redux-sidebar { - width: 44px; - - .extraIconSubsections { - display: none !important; - } - - .redux-group-menu li a, - .redux-group-menu li a:hover, - .redux-group-menu li.active a, - .redux-group-menu li.active a:hover, - .redux-group-menu li.activeChild a, - .redux-group-menu li.activeChild a:hover { - width: auto; - } - - .redux-group-tab-link-a { - position: relative; - - i { - position: inherit; - } - - span { - display: none; - position: absolute; - top: 0; - left: 44px; - padding: 12px; - width: 200px; - background: #eeeeee; - border: 1px solid #ccc; - -webkit-box-shadow: 2px 2px 8px rgba(0, 0, 0, .2); - -moz-box-shadow: 2px 2px 8px rgba(0, 0, 0, .2); - box-shadow: 2px 2px 8px rgba(0, 0, 0, .2); - border-width: 1px 1px 1px 0px; - z-index: 3; - } - - &:hover > span { - display: block; - } - } - } - - .redux-main { - margin-left: 43px; - width: auto; - max-width: 100%; - } - - table.form-table, - .form-table > thead, - .form-table > tbody, - .form-table > tbody > tr > th, - .form-table > tbody > tr > td, - .form-table > tbody > tr { - display: block; - width: 100% !important; - padding: 0px !important; - } - - .form-table > tbody > tr > th, .form-table > tbody > tr > td { - padding: 10px !important; - } - - .form-table > tbody > tr > th, .form-table > tbody > tr > td { - padding: 10px !important; - } -} - -//mp6 fixes -@media screen and (max-width: 782px) { - .form-table>tbody>tr>th { - width: 100%; - } - .redux_field_th { - padding-bottom:0; - } - .mp6 { - .redux-container { - #info_bar { - height: auto; - padding-bottom: 1px; - - a { - margin-top: 5px; - } - } - } - } - .redux-container-switch label { - padding: 5px 10px !important; - - } - .redux-container-button_set label { - padding: 12px 10px; - } - .redux-container #redux-footer #redux-share { - line-height: 34px; - } - -} - -pre { - overflow: hidden; -} - -/* Default admin theme */ -#redux-header h2 { - color: #fff; -} - -@mixin backgroundGradient($to: darken($to, 5%), $from: lighten($to, 7%)) { - background-color: $to !important; - background-image: -khtml-gradient(linear, left top, left bottom, from($from), to($to)) !important; - background-image: -moz-linear-gradient(top, $from, $to) !important; - background-image: -ms-linear-gradient(top, $from, $to) !important; - background-image: -webkit-gradient(linear, left top, left bottom, color-stop(0%, $from), color-stop(100%, $to)) !important; - background-image: -webkit-linear-gradient(top, $from, $to) !important; - background-image: -o-linear-gradient(top, $from, $to) !important; - background-image: -linear-gradient(top, $from, $to) !important; - - filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#{$from}', endColorstr='#{$to}', GradientType=0) !important; -} - -@mixin adminThemeColorOverrides($darkColor, $accentColor, $secondaryColor, $buttonPrimary) { - - .button.ui-datepicker-current, - button.ui-datepicker-close { - background-color: lighten($accentColor, 3%) !important; - } - - .ui-datepicker-buttonpane button.ui-datepicker-current { - background: $buttonPrimary !important; - color: white !important; - border: 1px solid darken($buttonPrimary, 20%) !important; - - } - - .ui-datepicker-header .ui-icon { - background-image: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAQAAAADwCAMAAADYSUr5AAAA7VBMVEX8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vz8/vywC3+8AAAATnRSTlMAGBAyBAhQv4OZLiJUcEBmYBoSzQwgPBZCSEoeWiYwUiyFNIeBw2rJz8c4RBy9uXyrtaWNqa2zKP2fJO8KBgKPo2KVoa9s351GPm5+kWho0kj9AAAPhUlEQVR4nO1djWLbthEGyUiq5YSSLXtp7FpLOmfzkmxr126tmi2p03RJ1/Xe/3EGgARxPyAgRbIk2/hkSz4CJO4+HsE7AJSVysjI2AMUUOxahZ2iANhzBtZWr4BoIRSYAVN5u4QwDwQDRbcwfUi5KS3wFuDmFnQLa4Dtb//cqktwD5QEFFwfUs7PoCCA7y4bEJVFizcIob8KmhAplwwqVjt+9FBl3uINQniwEiryEyw9JHqGpQdEFNi+B4QQ7QOiHhysIPoAxUqxvdvvA9K42bsAv4S2fxfYOe57IJSRkZGRkZGxx7jxSHDHcRBXQMTyIjInBgHwBJ/bEx8PEANC+uhbpSSggCBAVODVabpI1S/k4WLZpTn6NpMhoX9Y40hxYERFpMcqUs4AloCtDQdID1YhnyXZ2hLjAYWiO9Dy1PDB7tPhIqLx+uMB8grZaR+Qxl2/C2RkZGRkZGRk7A7rBf7J0DR5/LUTjzUPIPSPGvQJiVJiB7kcQCiUOJrcFNtDZIf2xarQ3aGvLNxAVIFAabz90BFiBIlycTBhgWwOWCH0FLYHlPqwHaCvcIn2ZbosCevfPTRiFFcgvHukCjWwrc3GrGh1fsAof8EaUReKXkCB4/MzFNo97qLpFiKFYv/kNR5YQxQbQEofkZ2OuEOHqqT6gFTpru8CN7x/+jaZkZGRkZGRcV+x/rLUNcMMqUAscgnFocmpqkTzqymwVAPxfJ5PnIUUQOUKT04tEdWZyv3JCQSn96WS4pD97QfyW25A7NhSAbyhmVj0FEltA4vdiygBibXhoUYgykCUP7HwPTDeEqAIcHVMkZg7Zx4k0uFANs63hPQXCoRLAwdgGsr9Az7Qv7sgQGgg1aPl/BJLExBWgG4RFRLFImGmIquPC/klEGyCG0AuAXaJJC+B8FVe9NYQDEcXB8g6AQcjYJ1goJIggHWCrFR0S6kRHN5+4BzFi8NaoN35NRxUvL+JJdZr7PV4wK6fj8nIyMjIyNhr3OxdXAYq7FHZwB6bDSzSh4sF0utChqo0NAvaT1hLzXwFinmCzmeDucEQK18TTaQoFgP7bNC+RZ4OT4T6gQogDFYk+1QxQlj19QGSAWKiLYp8P0Ag1Gbz1ULfWHLg9iUnQNK5QQJcukm04blKLH2GgEJCY+HzXAZWCvHKco3Bp6MIaCjSXXRJyOxeqhnzEaF93MfFGW/O16ZvDL5TM4MJIjujz/cHypkQuuzRwWJ93BKdIt+wCRAPl9kpe2Ikkb2mFgGlxh/i40d3EHfdvoyMjIyMu43ylt/IAmGHnN5iIt7wKfbv01RAcJqFRl9lcjYQSnbQqKgC4fYOwSJt6N6trE0twZ9kN/PqNpTQeICvr4TLsDYC06U7BMjshS+v1/aT7IwQYD5LcgRQXMT2FrBfBLjZ6151jDElk9tPFfpUgk2yregusX25BJbwAFEfM+YI6vGAti4bTtizB+TjfQCrERyhKb2X8D6A9wX75P4t4neBYJeP6pdhg/gQl8MWvytzeSTjgOQBynQdh/iXKdxOrGJ/RkZGRsb9QmXihGr5+g8GGg9uTh+KoVZuNIzV+CwRucFBEyr1mVjx4irOxwM1BhirB6Q+2eNQi4eqR+aF6mELtoMzCR7V9RAFe/ZvQogNiyY8FPSUTFsLp8TeTmMui5mtw7bcaT0Yw2AA4wFRQIlkgq+1DQrNhkmoxS5Jq+u6bMAIGRECEANgXHTgWzwgBOhDH2l0oTQ4D8D5NMktBgNywAEMjo8rwATMZrPY7JGxBoJCkIBDQiAY09EGTUiBCWkUpISfGPR5AAwBfZiG2z7Ayc1yeKTxid39xBNwfHr4O0LA48ePFTvhYrF1r4tyAoz9n2MCqEuBtp/6GDR0oAYfG/R6wJExHYZHfhygsv7fEWCOj4bYmsP5A+pL4MkTfAnMlD4F+r3bobKvTyTA2P/w7PN+Agq2QW8piqMCpTBwenoKvX0AHGkGtP2YAPvTEWA7QUTAudn7/NxtOG46wWNmDtpBEkBzN7rBEvAFHp+YTB/q97qPAN4gHFqgBi8uLsC7qPCA6mg41G/+ErByPwEXDdoNxRhOx+M5jPEzQugS0ht+b1/Y3gEnYMAIAOIBE29/hIDucE8tmMsNOgK4B1RHFu4UCRlMHzv0xzcajcfdXWDs2h8TArBCkoDUJYDLmz6w7ip3BFS0ve5wTRwAn6keMA9I3QYbfSZ0DKbyt+7OXjGI1idPcfNyAyfAMlCrzaGqphYrxHocLHRJVycnfGUcbtT+jIyMjIw9x7Nn8fJSzG0TmFtO8rZT+XT3S3ub+tKJbbLd5diTVp50+zahyeHSslJ/YPrU0fuazrZO2CZ92/ZCCVXlGRiZKPJyPPRxyIFWeXLQBXJBKiq/3divEAN6ZwM200Qjm7EJBZeWm/PRWVCbYK7s7u2l4XaCz+lzgOfMfhMonXr7TWzeZb98dbgIzBT8Ub8eYYUqfZ4rVJ/MDbIDgPqTulJ/xvntWAtjIisqnwxOkGz0n077FARoY79GdA6HPE4rOy196NiMWHTZlSSApcOgXpy/fHV2joaNKu3ffsAnRcBf4K/6NcIG6tIxk3HyoXPjASqfUgXbYN5PzpL2njkR9QMjeDTVHDTCgRuxOegjoO0FvKzP/t/gmVdI24+G7NIe8JX6Wv3dDyldMA+4YB5wwTygtd+dwRqaTqrLb1l73zTSN52CNpnHuQOYPsDblybgxfkXh/oVtr+N1DEBJdhRJyd/Bd/q1z+cbNrD17iVKyajcnv9arhOkRPgsruuD6DmNPwpDNrLw2CoTgHni4yALr0L29+tiKAEIPn868ejx//8rpWP3OEOl5On9OwpcQm0MhafP/ey8f1uvDNIgGLQG8z4YO99ENgg95etwv4uYJYY8fUGHYH6j6fscHFZMftlAl9i+9XL73X3N/n+ZStOzfVfRvYXhrbdKOpEgVQTg/wsDuDD3kwOfQNMTJ5y+/ltUDWLunyxnRF46IqlBzGMY4X7inggREFioIyMjIyMHWCIB6ZNKAcXseo3vLTQTkVE7348dlwJJSz0+wLfmi8BhZqfw3D4ww/wHVLnEd5/fgYvXsDZ3MlsvYUbbnDjDZ3MN3TJG4+bxjAaDl8TBri9qxEw1ccao2wTNAMLHo2f+sjrXwb/9qHoYqgPMBXJTVfOpmrZH23y6uvo0LHSyY6fHGwKfHJlAuMFvObjDYrIqxBgQi20h7Hd/nYVLmno+eaNUm/eeH2GCuopntnhBJAlI2AHo9CCh1I1QxUdAbqqGY9BBLwyc3W4wYVhvY8A4BoIc1l5M7vnPWphZW9/Ses3n37y9a0uGqFwFQZsQQbd386DogpgEk+dzynsAZMJXq8+ns9NeukJ0PYrNATGGefJQlhkLo7DTXr+y3bNiOsDvrXTz/C2q1DXZH84iRNwrP88Nj+u2DjYEE6RBxD9Knj16ujVHC67A7422o02RwD3gB+t7EblWvu9geOFxSnd3ROmT+nJyQkhoPlsxVONc/3TEdBos+jtA+ZzcwHgTvD1cDjaYCcItA8w9i88A8b+mqSjc6Pvqd998QguEQPmQMeo23ODN86+p0/bn1buBkT6+oBhNZ/PYY4ZAHYb3PRd4LkZmPX68NRtMZn4ASvdA+qf0jMA5MP9eeg28Nug9QiLnj5A33U1MAES6xHAUNpz/9zFAYE1gqQDMT3G6xI9pwdw/aIgKoHCS1YGlRnSq9yCjdXjgN3j+N27YyROHxmuNAeNKPpYuXIyIyMjYy0M8eros59MF/PT2c602T7eA7zvhJ9dr/vzDjXaLp4Yc5+0wllzxzHv3gdmMMM7/CcQzKgVBqYTmFn+Z+mKm8J7k0A5F/jgCfjQ1WBhQyiOqD0lYuqBb+AyzMw9Ha2G3m6c8qQx+AlqnIceQp+Sb6i9UyQWbhr54+AjnZ0VzW2TAN0DmBT6PWmc6jDBE2PK2u+nF43dyP7Q0t1pOcX2fdRvH0mF2Q4JqN35rnHjVIeaXfIAVyUuw/aHCCiJy9iF5l1621zweI8KZrPZ9iJdb7DXJ3US0OSrtZ10imt7wHY7QesAzUMz1oZ3noB3qFJ/H18j97FYuw8QDN4oeKf30osvcSW2ExLo+VcbuAuo/sUIm8fMG9xocO3Ea19J9gFYivnHJ2KnyfovZlgW3v6ySx32abQiIyMjIyPjhlFDTLxpwIgFMnTp6A3g4IDKNY+stkwAMAoIAbasxBXqUWneSAWTMjt50lTqT29rFjvXohjsDNm2YPXDFlICmrJOZ3t6tHm8AiEAl0sCeLIIorIRt+cFbew/QRsoAXb4o1XSfoywzm0FTMAoYBNvLyFu8v8HpLBtD1iKgC17wHb7AI6d9wFbvguAIGTHd4E9wG7jgIyMjIyM+434c2R3HeV/Ffx6jtZu6ijl8h59T655jhR+rdHzDOP6beABCheb8O8/WFXeOyzgf5oAhVYnKxP7CwaAf1afJu8bSrhS6tdaXeGnrRenOqOlz9d6QwYnA/3TLd+GE7qe3chA5YF5DfY0vK3adfOX/gyNp2BW25MHdxAB9qvRiiP3/XpQQFGYDU4+Mi///XumXG8pjvaUAOsBGlf4jJt+YYEzeEzAdw06F19R3juM7D1wita86GR0CKfDHgLuXCc4Bri6vMLdfjMc4VNSUNsdodo2xu/1+Xl/K5+az8jIyMhYG/z5gJTMF1GtKq/a3rpyCvz5gJTMl9GtKq/a3rpyCmfQ4WwZmS+kXFVetb115ST48wEf/AGcfG1iw+tWbpbS2vJ3nQxcVr3lH3z5h972FUTLzYpOVk7l5hD+eYcYwDcAnewOotrZ4OtrPDucqi/LRX0/RR4qx7Nn4U8g+qjffvuN6Gf+nC85vwauHjaYyubqvWYKY4VEfSUMitdnBCT1Ue63R5439m+OgCn6DroAAaHPVQxKth/wkJgHmG8bmQMsT0D6EjDfvhVRKO3ywOQUgRA7nmL1uawZmHf1k+DPBwQ6NdcJ+k6Md1LA5f5ONdhJ8vZ5J0vLHT99srkGOjmJbd/G1r2Nriqnse1AZt1AalU5jW2HsuuG0qvKGRkZGRkZGRG0gcONyXsP9v8D0/IdJADiBNiXl3327WRGgOL/9HC/0XwlIURkRhC4tz6Z/fu7fUf2gHvfB9z3u0BGRkZGRkbGplHcnkgguQoSqtUXuhbs/wPtMwqV0HUJAvj5vk32b8IDuL23yn7qAXZ5u32hbRX7d3o82Df1FZXvbh9QOfhyxldr/+3xgXU9oKmvsHyr7F/XA269/eveBXrsv7N9QALe/tvjA0kPWAXGbvebkbHn+D/J5nMcHzx1UAAAAABJRU5ErkJggg==) !important; - } - - .ui-datepicker-header { - background-color: $secondaryColor !important; - color: white !important; - } - - .ui-datepicker td .ui-state-active { - background-color: lighten($accentColor, 3%) !important; - color: white !important; - } - - .ui-datepicker td .ui-state-hover { - color: lighten($accentColor, 3%) !important; - } - - .ui-datepicker td .ui-state-highlight { - background: $accentColor !important; - border: 1px solid $secondaryColor !important; - color: white !important; - } - - .redux-container-switch .cb-disable, - .redux-container-switch .cb-enable, - .ui-state-default, - .ui-widget-content .ui-state-default, - .ui-widget-header .ui-state-default { - @include backgroundGradient(#f5f5f5, #f8f8f8); - border-color: #ccc !important; - } - - .ui-datepicker td .ui-state-active { - color: black !important; - font-weight: 700 !important; - background: white !important; - } - - .redux-container-switch .cb-disable.selected { - @include backgroundGradient(#646464, #929292); - border-color: #767676 !important; - } - .redux-container-switch .cb-enable.selected, - .redux-field-container .ui-buttonset .ui-state-active { - @include backgroundGradient($accentColor); - border-color: darken($accentColor, 15%) !important; - border-color: darken($accentColor, 10%) !important; - -webkit-box-shadow: inset 0 1px 0 lighten($accentColor, 15%), 0 1px 0 rgba(0, 0, 0, .15) !important; - box-shadow: inset 0 1px 0 lighten($accentColor, 15%), 0 1px 0 rgba(0, 0, 0, .15) !important; - - } - - #redux-header { - background: $secondaryColor; - border-color: $accentColor; - - .display_header span { - color: $darkColor; - } - } - - .redux-sidebar .redux-group-menu li.active { - &.hasSubSections { - - a { - position: relative; - &:after { - right: 0; - border: solid 8px transparent; - content: "\0020"; - height: 0; - width: 0; - position: absolute; - pointer-events: none; - border-right-color: #fff; - top: 50%; - margin-top: -8px; - } - - } - ul.subsection li a:after { - border: 0 none !important; - content: "\0020" !important; - } - } - } - .redux-sidebar .redux-group-menu li { - &.hasSubSections { - .redux-menu-error { - display: none; - margin-right: 5px; - } - - a { - &.hasError { - .extraIconSubsections { - background-color: rgb(185, 74, 72); - color: rgb(242, 222, 222); - } - } - .extraIconSubsections { - border-radius: 10px; - -moz-border-radius: 10px; - -webkit-border-radius: 10px; - border: 0 solid transparent; - float: right; - font-size: 9px; - height: 9px; - line-height: 9px; - margin-right: 5px; - padding: 6px 7px 4px 7px; - width: 5px; - } - - &:hover .extraIconSubsections { - //right: 2px; - } - - } - } - &.active, - &.activeChild { - a .extraIconSubsections { - display: none; - } - &.hasSubSections { - .redux-menu-error { - display: block; - } - .subsection { - .redux-menu-error { - margin-right: 2px; - } - } - } - } - } - - .redux-sidebar .redux-group-menu { - li.active, - li.activeChild { - border-left: 0 none; - a { - color: $secondaryColor; - } - &.hasSubSections { - .active { - a { - &:after { - right: 0; - border: solid 8px transparent; - content: "\0020"; - height: 0; - width: 0; - position: absolute; - pointer-events: none; - border-right-color: #fff; - top: 50%; - margin-top: -8px; - } - } - } - a { - -webkit-transition: all 0.2s; - -moz-transition: all 0.2s; - transition: all 0.2s; - color: #fff; - width: auto; - border-bottom: 0; - } - ul.subsection li { - border-top: 0 none !important; - &.active a:hover { - color: #fff; - } - a { - width: auto; - border-top: 0 !important; - // border-top-color: lighten(@secondaryColor, 15); - padding: 7px; - color: #fff; - padding-left: 15px; - -webkit-transition: all 0.2; - -moz-transition: all 0.2; - -ms-transition: all 0.2; - -o-transition: all 0.2; - transition: all 0.2; - &:hover { - color: $buttonPrimary; - background: darken($secondaryColor, 10%); - } - span.group_title { - padding-left: 5px !important; - } - } - &.hasIcon { - a { - padding-left: 14px; - span.group_title { - padding-left: 30px !important; - } - - } - } - } - } - } - li.active { - &.hasSubSections { - a { - background: $accentColor; - } - ul.subsection li a { - background: $secondaryColor; - } - } - } - li.activeChild { - &.hasSubSections { - a { - background: $darkColor; - text-shadow: 1px 1px darken($darkColor, 30%); - } - ul.subsection li { - a { - background: $secondaryColor; - text-shadow: none; - } - &.active { - a { - background: $accentColor; - text-shadow: 1px 1px darken($accentColor, 20%); - } - } - } - } - } - } - - .redux-container-image_select .redux-image-select-selected img { - border-color: $accentColor; - } - #redux-footer #redux-share a { - color: $accentColor; - &:hover { - color: darken($accentColor, 20%); - } - } - .select2-results .select2-highlighted { - background: $accentColor; - } - .select2-drop-active, - .select2-container-multi.select2-container-active .select2-choices, - .select2-drop.select2-drop-above.select2-drop-active, - .select2-container-active .select2-choice, - .select2-container-active .select2-choices, - .select2-dropdown-open.select2-drop-above .select2-choice, - .select2-dropdown-open.select2-drop-above .select2-choices { - border-color: $accentColor; - } - .select2-dropdown-open.select2-drop-above .select2-choice, - .select2-dropdown-open.select2-drop-above .select2-choices { - border-top: inherit; - } - .noUi-connect { - @include backgroundGradient(lighten($accentColor, 3%)); - } -} - -/* Light fresh theme */ -.admin-color-fresh, .wp-customizer { - @include adminThemeColorOverrides(#a0a5aa, #0073aa, #23282d, #1e8cbe); -} - -/* Light admin theme */ -.admin-color-light { - @include adminThemeColorOverrides(#e6e6e6, #04a4cc, #888888, #0384a4); -} - -/* Blue admin theme */ -.admin-color-blue { - @include adminThemeColorOverrides(#e2ecf1, #4796b3, #096484, #db9825); -} - -/* Coffee admin theme */ -.admin-color-coffee { - @include adminThemeColorOverrides(#cdcbc9, #c7a589, #46403c, #ba906d); -} - -/* Ectoplasm admin theme */ -.admin-color-ectoplasm { - @include adminThemeColorOverrides(#cbc5d3, #a3b745, #413256, #89993a); -} - -/* Midnight admin theme */ -.admin-color-midnight { - @include adminThemeColorOverrides(#c2c4c5, #e14d43, #363b3f, #d92c23); -} - -/* Ocean admin theme */ -.admin-color-ocean { - @include adminThemeColorOverrides(#d5dddf, #9ebaa0, #627c83, #86a988); -} - -/* Sunrise admin theme */ -.admin-color-sunrise { - @include adminThemeColorOverrides(#f0c8c6, #dd823b, #b43c38, #cc6c23); -} - -@media screen and (max-width: 600px) { - // .redux-group-tab-link-a span { margin-top: -2px; } - .redux-group-tab-link-a { - min-height: 15px; - span { - //background: #222; - //color: white; - padding: 11px 12px; - color: #555; - -webkit-transition: all 0.3s; - -moz-transition: all 0.3s; - transition: all 0.3s; - &:hover { - //color: #2ea2cc; - //background: black; - background: #e5e5e5; - } - text-shadow: none !important; - } - } - - .redux-sidebar a { - - } -} - -@media screen and (max-width: 782px) { - #redux-footer #redux-share { - line-height: 38px; - font-size: 18px; - } - - .sticky-save-warn .redux-save-warn { - right: 13px; - top: 46px; - } - - .redux-container .expand_options { - margin-top: 5px; - } - - .redux-action_bar input { - margin-bottom: 0 !important; - } - -} - -@media screen and (max-width: 600px) { - #redux-footer #redux-share, - .redux-hint-qtip { - display: none; - } - - .redux-container .redux-action_bar { - float: none; - } -} - -// WP Engine CSS fix -.redux-sidebar .icon-large, -.redux-main .icon-large { - background-image: inherit !important; - width: inherit; - height: inherit; -} - -.redux-main dd, .redux-main li, .redux-sidebar li { - margin-bottom: 0 !important; -} - -.fully-expanded { - .redux-sidebar { - margin-left: -500px; - } - .redux-main { - margin-left: 0; - } - .redux-group-tab { - display: block; - } -} -@media screen and (max-width: 640px) { - #redux-defaults-section { - display: none; - } -} -@media screen and (max-width: 730px) { - #redux-share { - display:none; - } -} -@media screen and (max-width: 730px) { - #redux-defaults-section2 { - display: none; - } - #redux-share { - display:none; - } -} - -@media screen and (max-width: 600px) { - .form-table > tbody > tr > th { - padding-bottom: 0 !important; - } - - .redux_field_th { - padding-top: 0; - padding-bottom: 0; - } - - .redux-main { - .redux-field-container { - padding-top: 0; - padding-bottom: 0; - } - .subsection a { - min-height: 15px; - } - } -} - -@media screen and (min-width: 601px) and (max-width: 782px) { - .redux-container { - .sticky-save-warn .redux-save-warn { - top: 47px !important; - right: 13px !important; - } - } -} - -@media screen and (max-width: 782px) { - - .redux-main { - .form-table-section-indented { - input[type=text] { - width: 95% !important; - } - } - - .redux-container-sortable { - input[type=text] { - width: 80%; - display: initial; - } - } - - .redux-typography-container { - .input_wrapper input.mini { - font-size: 16px !important; - height: 40px !important; - padding: 7px 10px !important; - line-height: 24px !important; - } - .picker-wrapper label { - margin-top: 16px !important; - } - } - - .input-append { - height: 50px !important; - - .add-on { - font-size: 16px; - line-height: 24px !important; - padding: 7px; - height: 32px !important; - float: right; - margin-top: -40px; - } - } - - .redux-hint-qtip { - float: left !important; - } - .redux-action_bar .button { - margin-top: -1px; - } - } -} - -@media screen and (max-width: 600px) { - .sticky-save-warn .redux-save-warn { - top: 0 !important; - right: 14px !important; - } -} - -@media screen and (max-width: 570px) { - .redux-main { - .redux-container-sortable { - .checkbox-container { - width: 85%; - padding-bottom: 5px; - - label { - display: initial; - } - } - } - } -} - -#redux-header { - position: relative; -} - -/* Leftovers? */ - -/*.shadow1 { - position: relative; - - &:before, - &:after { - z-index: -1; - position: absolute; - content: ""; - bottom: 15px; - left: 10px; - width: 50%; - top: 80%; - max-width: 300px; - background: #777; - -webkit-box-shadow: 0 15px 10px rgba(0,0,0,0.4); - -moz-box-shadow: 0 15px 10px rgba(0,0,0,0.4); - box-shadow: 0 15px 10px rgba(0,0,0,0.4); - -webkit-transform: rotate(-3deg); - -moz-transform: rotate(-3deg); - -o-transform: rotate(-3deg); - -ms-transform: rotate(-3deg); - transform: rotate(-3deg); - } - - &:after { - -webkit-transform: rotate(3deg); - -moz-transform: rotate(3deg); - -o-transform: rotate(3deg); - -ms-transform: rotate(3deg); - transform: rotate(3deg); - right: 10px; - left: auto; - } -}*/ - -/*.redux-menu-warning { - background-color: #C09853; - color: #FCF8E3; -} -.redux-menu-error { - background-color: #B94A48; - color: #F2DEDE; -}*/ - -/*.redux-screenshot { - max-width: 300px; - display: block; -}*/ - -/*.redux-container { - .ajax-loading-img-top { - margin: 5px 4px 0; - float: left; - } - - .ajax-loading { - margin: 3px 4px 0; - float: right; - } - - .ajax-reset-loading-img { - display: block; - margin-left: 100px; - } -}*/ - -// Modern Theme - -.redux-main { - position: relative; - #redux-sticky { - min-height: 32px; - margin-left: -20px; - margin-right: -20px; - margin-top: -10px; - margin-bottom: 8px; - #info_bar { - height: 32px; - .expand_options { - margin-top: 4px; - } - } - } - .redux_field_search { - top: 50px; - right: 5px; - } - #redux-footer-sticky { - margin-left: -20px; - margin-right: -20px; - margin-bottom: -10px; - } -} -.redux-qtip { - z-index: 999999 !important; - -} - -.redux-main pre { - white-space: pre-wrap; /* css-3 */ - white-space: -moz-pre-wrap; /* Mozilla, since 1999 */ - white-space: -pre-wrap; /* Opera 4-6 */ - white-space: -o-pre-wrap; /* Opera 7 */ - word-wrap: break-word; /* Internet Explorer 5.5+ */ -} \ No newline at end of file diff --git a/library/admin/ReduxCore/assets/css/redux-fields.css b/library/admin/ReduxCore/assets/css/redux-fields.css deleted file mode 100644 index c0ef245d..00000000 --- a/library/admin/ReduxCore/assets/css/redux-fields.css +++ /dev/null @@ -1 +0,0 @@ -.redux-container-ace_editor .ace-wrapper{position:static}.redux-container-ace_editor .ace_editor{height:200px;-webkit-border-radius:3px;-moz-border-radius:3px;border-radius:3px}.redux-container-ace_editor .ace_gutter{z-index:1!important}.redux-main .redux-container-background .redux-background-attachment,.redux-main .redux-container-background .redux-background-attachment select,.redux-main .redux-container-background .redux-background-clip,.redux-main .redux-container-background .redux-background-clip select,.redux-main .redux-container-background .redux-background-origin,.redux-main .redux-container-background .redux-background-origin select,.redux-main .redux-container-background .redux-background-position,.redux-main .redux-container-background .redux-background-position select,.redux-main .redux-container-background .redux-background-repeat,.redux-main .redux-container-background .redux-background-repeat select,.redux-main .redux-container-background .redux-background-size,.redux-main .redux-container-background .redux-background-size select{width:200px!important;margin-right:10px;margin-bottom:7px}.redux-main .redux-container-background .background-preview{display:block;width:100%;margin:5px 0 10px;border:1px dotted #d3d3d3}.redux-main .redux-container-background .select2-container{margin-right:10px;margin-bottom:10px}.redux-main .redux-container-background .wp-picker-container{margin-bottom:10px}.redux-main .redux-container-background .upload{width:100%;margin-bottom:8px}.redux-main .redux-container-select li.ui-state-highlight{height:20px;margin-top:2px;margin-left:5px;width:64px;margin-bottom:0}.wp-customizer .redux-container-background .redux-background-attachment,.wp-customizer .redux-container-background .redux-background-attachment select,.wp-customizer .redux-container-background .redux-background-clip,.wp-customizer .redux-container-background .redux-background-clip select,.wp-customizer .redux-container-background .redux-background-origin,.wp-customizer .redux-container-background .redux-background-origin select,.wp-customizer .redux-container-background .redux-background-position,.wp-customizer .redux-container-background .redux-background-position select,.wp-customizer .redux-container-background .redux-background-repeat,.wp-customizer .redux-container-background .redux-background-repeat select,.wp-customizer .redux-container-background .redux-background-size,.wp-customizer .redux-container-background .redux-background-size select{width:100%!important}.redux-container-border .select2-container{float:left;display:block;margin-right:10px}.redux-container-border .select_wrapper{float:left;width:inherit}.redux-container-border .select_wrapper select{width:80px;float:left}.redux-container-border .field-border-input{margin-right:10px;margin-bottom:7px}.redux-container-border .wp-picker-container{margin-top:2px}@media screen and (max-width:782px){.redux-container-border .field-border-input input{display:inline-block!important;width:100px!important}.redux-container-border .field-border-input .add-on{padding:7px 4px;font-size:16px;line-height:1.5}.redux-container-border .select_wrapper{margin-top:6px}}.redux-container-checkbox label{vertical-align:top;width:100%}.redux-container-checkbox label .field-desc{margin-top:0;float:left;width:93%;clear:none}.redux-container-color_gradient .colorGradient{display:inline-block}.redux-container-color_gradient .toLabel{padding-left:18px}@media screen and (max-width:660px){.redux-container-color_gradient .colorGradient{display:block;text-align:center!important}}.sp-container,.sp-replacer{color:#555;border-color:#ccc;background:#f7f7f7;-webkit-box-shadow:inset 0 1px 0 #fff,0 1px 0 rgba(0,0,0,.08);box-shadow:inset 0 1px 0 #fff,0 1px 0 rgba(0,0,0,.08);vertical-align:top}.sp-replacer.focus,.sp-replacer.hover,.sp-replacer:focus,.sp-replacer:hover{background:#fafafa;border-color:#999;color:#222}.sp-replacer.focus,.sp-replacer:focus{-webkit-box-shadow:0 0 0 1px #5b9dd9,0 0 2px 1px rgba(30,140,190,.8);box-shadow:0 0 0 1px #5b9dd9,0 0 2px 1px rgba(30,140,190,.8)}.sp-replacer.active:focus{-webkit-box-shadow:inset 0 2px 5px -3px rgba(0,0,0,.5),0 0 0 1px #5b9dd9,0 0 2px 1px rgba(30,140,190,.8);box-shadow:inset 0 2px 5px -3px rgba(0,0,0,.5),0 0 0 1px #5b9dd9,0 0 2px 1px rgba(30,140,190,.8)}.sp-replacer.active,.sp-replacer.active:hover,.sp-replacer:active{background:#eee;border-color:#999;color:#333;-webkit-box-shadow:inset 0 2px 5px -3px rgba(0,0,0,.5);box-shadow:inset 0 2px 5px -3px rgba(0,0,0,.5)}#ui-datepicker-div{z-index:15!important}.ui-datepicker-header{background-color:#00abef}.redux-dimensions-container .select_wrapper,.redux-dimensions-container select{width:65px!important;float:left}.redux-dimensions-container .field-dimensions-input{margin-right:10px;margin-bottom:7px}@media screen and (max-width:782px){.redux-dimensions-container .field-dimensions-input input{display:inline-block!important;width:100px!important}.redux-dimensions-container .field-dimensions-input .add-on{padding:7px 4px;font-size:16px;line-height:1.5}.redux-dimensions-container .select_wrapper{margin-top:6px}}.redux-main .divide{float:none;border-color:#E7E7E7;display:block;width:100%;height:35px!important;line-height:35px!important;position:relative;margin:15px 0 10px}.redux-main .divide .inner,.redux-main .divide .inner span{background-color:#FCFCFC;border-color:#E7E7E7;position:absolute}.redux-main .divide .inner{width:42%!important;left:40%!important;margin-left:-6%;height:1px;top:50%;margin-top:-1px;border-top-width:1px;border-top-style:solid}.redux-main .divide .inner span{height:5px;width:5px;border-width:2px;border-style:solid;display:block;left:50%;margin-left:-5px;margin-top:-5px}.wp-customizer .redux-container-divide .divide .inner{width:82%!important;left:18%!important;margin-left:-8%}.redux-container-editor .mceLayout td{border-width:1px;margin:0;padding:1px}.redux-container-editor input,.redux-container-editor textarea{margin:inherit}.redux-container-editor textarea{border:0}.redux-container-editor .wp-editor-container{-webkit-border-radius:3px;-moz-border-radius:3px;border-radius:3px}.redux-container-editor .wp-editor-container textarea{-webkit-border-radius:0;-moz-border-radius:0;border-radius:0;border-style:inherit}.redux-container-editor .quicktags-toolbar input{margin:2px 1px 4px;line-height:18px;display:inline-block;min-width:26px;padding:2px 4px;font:12px/18px Arial,Helvetica,sans-serif normal;color:#464646;border:1px solid #c3c3c3;-webkit-border-radius:3px;border-radius:3px;background:#eee;background-image:-webkit-gradient(linear,left bottom,left top,from(#e3e3e3),to(#fff));background-image:-webkit-linear-gradient(bottom,#e3e3e3,#fff);background-image:-moz-linear-gradient(bottom,#e3e3e3,#fff);background-image:-o-linear-gradient(bottom,#e3e3e3,#fff);background-image:linear-gradient(to top,#e3e3e3,#fff)}.redux-container-image_select .redux-table-container{display:table;table-layout:fixed;width:100%}.redux-container-image_select .redux-image-select{margin:0!important}.redux-container-image_select .redux-image-select .tiles{display:block;background-color:#FFF;background-repeat:repeat;width:40px;height:40px}.redux-container-image_select .redux-image-select .tiles,.redux-container-image_select .redux-image-select img{border-color:#d9d9d9}.redux-container-image_select .redux-image-select li:last-child{margin-bottom:0}.redux-container-image_select .redux-image-select input[type=radio]{display:none}.redux-container-image_select .redux-image-select-presets img{width:100%}.redux-container-image_select ul.redux-image-select li{margin:0 10px 3px;display:inline-block;padding:2px 2px 2px 0}.redux-container-image_select .redux-image-select-selected{background-color:#f9f9f9}.redux-container-image_select .redux-image-select .tiles,.redux-container-image_select .redux-image-select img,.redux-container-image_select .redux-image-select-selected .tiles,.redux-container-image_select .redux-image-select-selected img{border-width:4px;border-style:solid}.redux-container-image_select .redux-image-select-selected .tiles{border-color:#7a7a7a}.redux-info-field .redux-info-icon i,.redux-notice-field .redux-info-icon i{font-size:2em}.redux-info-field .redux-info-desc,.redux-notice-field .redux-info-desc{display:inline-block;vertical-align:top}.redux-info-field{min-height:20px;padding:8px 19px;margin:10px 0;border-radius:4px;border:1px solid;position:relative}.redux-info-field h1,.redux-info-field h2,.redux-info-field h3,.redux-info-field h4,.redux-info-field h5,.redux-info-field h6{border-bottom:0!important}.redux-info-field h3{color:#777}.redux-info-field .redux-info-icon{display:inline-block;margin-right:15px}.redux-info-field.redux-normal{background-color:#eee;border-color:#ccc;color:#666}.redux-info-field.redux-normal i{color:#c5c5c5}.redux-info-field.redux-warning{background-color:#fbeba4;border-color:#d7c281;color:#958234}.redux-info-field.redux-warning i{color:#dcca81}.redux-info-field.redux-success{background-color:#c4ee91;border-color:#71af5d;color:#4d7615}.redux-info-field.redux-success i{color:#a0ca6c}.redux-info-field.redux-critical{background-color:#fba1a3;border-color:#b84f5b;color:#981225}.redux-info-field.redux-critical i{color:#dd767d}.redux-info-field.redux-info{background-color:#d3e4f4;border-color:#a9b6c2;color:#5c80a1}.redux-info-field.redux-info i{color:#afc6da}.redux-notice-field{margin:15px 0 0;background-color:#fff;border:0;border-left:4px solid #f3f3f3;-webkit-box-shadow:0 1px 1px 0 rgba(0,0,0,.1);box-shadow:0 1px 1px 0 rgba(0,0,0,.1);padding:1px 12px}.redux-notice-field h1,.redux-notice-field h2,.redux-notice-field h3,.redux-notice-field h4,.redux-notice-field h5,.redux-notice-field h6{border-bottom:0!important}.redux-notice-field p{margin:.5em 0;padding:2px}.redux-notice-field .redux-info-icon{display:inline-block;margin-right:15px}.redux-notice-field.redux-info{border-left:4px solid #0099d5}.redux-notice-field.redux-success{border-left:4px solid #7ad03a}.redux-notice-field.redux-warning{border-left:4px solid #fbeba4}.redux-notice-field.redux-critical{border-left:4px solid #dd3d36}.redux-main .redux-field-container.redux-container-info{padding:0}.wp-customizer .hasIcon.redux-info-field .redux-info-desc,.wp-customizer .hasIcon.redux-notice-field .redux-info-desc{display:block;margin-left:43px}.wp-customizer .hasIcon.redux-info-field .redux-info-icon,.wp-customizer .hasIcon.redux-notice-field .redux-info-icon{float:left}.wp-customizer .redux-main .customize-control.customize-control-redux-info{border-bottom:0}.redux-container-link_color .linkColor{display:inline-block;padding-right:10px;padding-bottom:7px}.redux-main .button.remove-image,.redux-main .removeCSS{margin-left:10px;color:#ef521d}.redux-main .button.remove-image:hover,.redux-main .removeCSS:hover{color:red}.redux-main .upload_button_div{margin-bottom:5px}.redux-main .upload-error{float:left;color:#666;font-size:10px;font-weight:700;text-decoration:none;text-shadow:1px 1px 0 #FFF;margin:0 10px 0 0;padding:3px 10px;background:#FFDFEC;-webkit-border-radius:4px;-moz-border-radius:4px;border-radius:4px}.redux-main .reset-button{font-family:Arial,Verdana,sans-serif;float:left;margin:0;color:#ef521d;border-color:#bbb}.redux-main .redux-option-image{max-height:340px;max-width:340px;padding:5px;margin-bottom:0;margin-top:10px;margin-right:15px;border:1px solid #e3e3e3;background:#f7f7f7;-moz-border-radius:3px;-khtml-border-radius:3px;-webkit-border-radius:3px;border-radius:3px}.redux-main .redux-main .upload{width:80%!important}.redux-main .button{margin-top:2px}.redux-container-multi_text ul.redux-multi-text{margin:0;padding:0}.redux-container-multi_text .redux-multi-text-add{clear:both;margin:5px 0}@media screen and (max-width:782px){.redux-container-multi_text input{clear:both}.redux-container-multi_text .redux-multi-text-remove{margin:0;float:right}}.deletion,.redux-container .redux-multi-text-remove,.redux-container a.redux-multi-text-remove{color:red;padding:2px 4px;margin-left:5px;background:orange}.deletion:hover,.redux-container .redux-multi-text-remove:hover,.redux-container a.redux-multi-text-remove:hover{background:red;color:#fff;text-decoration:none}.wp-customizer .redux-container-multi_text .button{float:right}.wp-customizer .redux-container-multi_text .redux-multi-text-remove{float:right;margin-bottom:5px}.wp-customizer .redux-container-multi_text ul.redux-multi-text input{width:100%!important}.redux-container-palette label{border:3px solid transparent;border-color:transparent!important;border-radius:0;width:100%!important;display:block}.redux-container-palette label.ui-button.ui-widget{width:95%;background:0 0;padding:0}.redux-container-palette label.ui-button.ui-widget .ui-button-text{display:flex}.redux-container-palette label.ui-button.ui-widget .ui-button-text span{padding:10px;flex-grow:1;font-size:0;line-height:10px;color:transparent;-webkit-transition:all 200ms ease-in-out;-moz-transition:all 200ms ease-in-out;-ms-transition:all 200ms ease-in-out;-o-transition:all 200ms ease-in-out;transition:all 200ms ease-in-out;text-shadow:0}.redux-container-palette label.ui-button.ui-widget .ui-button-text span:hover{flex-grow:3;font-weight:700;min-width:60px;font-size:12px;line-height:10px;color:#333;text-shadow:0 0 8px #fff,0 0 8px #fff}.redux-container-palette label.ui-state-active{border:3px solid #333!important}.wp-customizer .redux-main .redux-container-palette label{margin-bottom:3px}.redux-main .form-table-section-indented{width:95%;margin-left:5%}.redux-main .form-table-section tr:first-of-type th:first-of-type{padding:0!important}.redux-main h3{margin-top:10px}.redux-main .form-table-section-indented>tbody>tr:first-child{display:none}.redux-main .form-table-section-indented>tbody>tr:nth-last-child(2){border-bottom:0}.redux-container-select li.ui-state-highlight{height:20px;margin-top:2px;margin-left:5px;width:64px;margin-bottom:0}.redux-container-select_image{margin-top:2px;margin-left:5px;width:100%;margin-bottom:0}.redux-preview-image{max-height:250px;max-width:250px;padding:5px;margin-top:10px;border:1px solid #e3e3e3;background:#f7f7f7;-moz-border-radius:3px;-khtml-border-radius:3px;-webkit-border-radius:3px;border-radius:3px}.redux-container-slider .redux-slider-container{margin-left:25px;margin-right:25px;width:200px;display:inline-block;vertical-align:middle}.redux-container-slider .redux-slider-input,.redux-container-slider .redux-slider-select-one,.redux-container-slider .redux-slider-select-two{width:100px!important;text-align:center}.redux-container-slider .redux-slider-label{position:absolute;margin-left:-5px}.redux-container-slider .redux-slider-label-one{position:absolute;margin-left:-22px}.redux-container-slider .redux-slider-label-two{position:absolute;margin-top:-21px;margin-left:245px}@media screen and (max-width:782px){.redux-container-slider input{display:inline-block!important}}@media screen and (max-width:570px){.redux-container-slider{text-align:center}.redux-container-slider .redux-slider-label,.redux-container-slider .select2-container,.redux-container-slider input,.redux-container-slider select{display:block!important;position:inherit;margin:10px auto}.redux-container-slider .redux-slider-container{margin-top:3px;width:80%}}.wp-customizer .redux-container-slider .redux-slider-label{float:left;position:inherit;width:25%;text-align:center;margin-left:0}.wp-customizer .redux-container-slider .redux-slider-input,.wp-customizer .redux-container-slider .redux-slider-select-one,.wp-customizer .redux-container-slider .redux-slider-select-two{width:25%!important}.wp-customizer .redux-container-slider .redux-slider-container{width:70%;margin-right:0;margin-left:5%}.noUi-target,.noUi-target *{-webkit-touch-callout:none;-webkit-user-select:none;-ms-touch-action:none;-ms-user-select:none;-moz-user-select:none;-moz-box-sizing:border-box;box-sizing:border-box}.noUi-base{width:100%;height:100%;position:relative}.noUi-origin{position:absolute;right:0;top:0;left:0;bottom:0;border-radius:2px}.noUi-handle{position:relative;z-index:1}.noUi-stacking .noUi-handle{z-index:10}.noUi-state-tap .noUi-origin{-webkit-transition:left .3s,top .3s;transition:left .3s,top .3s}.noUi-state-drag *{cursor:inherit!important}.noUi-horizontal{height:18px}.noUi-horizontal .noUi-handle{width:34px;height:28px;left:-17px;top:-6px}.noUi-horizontal.noUi-extended{padding:0 15px}.noUi-horizontal.noUi-extended .noUi-origin{right:-15px}.noUi-vertical{width:18px}.noUi-vertical .noUi-handle{width:28px;height:34px;left:-6px;top:-17px}.noUi-vertical.noUi-extended{padding:15px 0}.noUi-vertical.noUi-extended .noUi-origin{bottom:-15px}.noUi-background{background:#FAFAFA;box-shadow:inset 0 1px 1px #f0f0f0}.noUi-connect{background:#3FB8AF;box-shadow:inset 0 0 3px rgba(51,51,51,.45);-webkit-transition:background 450ms;transition:background 450ms}.noUi-target{border-radius:4px;border:1px solid #D3D3D3;box-shadow:inset 0 1px 1px #F0F0F0,0 3px 6px -5px #BBB}.noUi-target.noUi-connect{box-shadow:inset 0 0 3px rgba(51,51,51,.45),0 3px 6px -5px #BBB}.noUi-dragable{cursor:w-resize}.noUi-vertical .noUi-dragable{cursor:n-resize}.noUi-handle{border:1px solid #D9D9D9;border-radius:3px;background:#FFF;cursor:default;box-shadow:inset 0 0 1px #FFF,inset 0 1px 7px #EBEBEB,0 3px 6px -3px #BBB}.noUi-active{box-shadow:inset 0 0 1px #FFF,inset 0 1px 7px #DDD,0 3px 6px -3px #BBB}.noUi-handle:after,.noUi-handle:before{content:"";display:block;position:absolute;height:14px;width:1px;background:#E8E7E6;left:14px;top:6px}.noUi-handle:after{left:17px}.noUi-vertical .noUi-handle:after,.noUi-vertical .noUi-handle:before{width:14px;height:1px;left:6px;top:14px}.noUi-vertical .noUi-handle:after{top:17px}[disabled] .noUi-connect,[disabled].noUi-connect{background:#B8B8B8}[disabled] .noUi-handle{cursor:not-allowed}.noUi-state-blocked .noUi-connect,.noUi-state-blocked.noUi-connect{background:#4FDACF}.redux-container-slides .redux-slides-list .select2-container{margin-bottom:10px;width:100%}.redux-container-slides .ui-accordion-header{margin-bottom:0}.redux-container-slides .full-text,.redux-container-slides .large-text{width:100%}.redux-container-slides .redux-slides-accordion-group{border:1px solid #dfdfdf!important;border-radius:3px!important;margin-top:0!important;margin-bottom:10px;background:#f9f9f9;padding:5px}.redux-container-slides .redux-slides-accordion-group h3{border:1px solid #dfdfdf;cursor:move!important;font-weight:700;padding:0 10px!important;height:40px;line-height:40px!important;background-color:#f1f1f1;background-image:-ms-linear-gradient(top,#f9f9f9,#ececec);background-image:-moz-linear-gradient(top,#f9f9f9,#ececec);background-image:-o-linear-gradient(top,#f9f9f9,#ececec);background-image:-webkit-gradient(linear,left top,left bottom,from(#f9f9f9),to(#ececec));background-image:-webkit-linear-gradient(top,#f9f9f9,#ececec);background-image:linear-gradient(top,#f9f9f9,#ececec);overflow:hidden;-webkit-border-radius:3px;-moz-border-radius:3px;border-radius:3px;-moz-box-shadow:inset 0 1px 0 #fff;-webkit-box-shadow:inset 0 1px 0 #fff;box-shadow:inset 0 1px 0 #fff;text-align:center}.redux-container-slides #redux-slides-accordion .redux-slides-image{height:250px;padding:5px;margin-top:10px;margin-bottom:10px;border:1px solid #e3e3e3;background:#f7f7f7;-moz-border-radius:3px;-khtml-border-radius:3px;-webkit-border-radius:3px;border-radius:3px}.redux-container-slides .redux-slides-add{float:right;margin-right:10%;display:block;margin-bottom:10px}.redux-container-slides .redux-slides-remove{color:#ef521d!important;float:right;margin-top:5px}.redux-container-slides .redux-slides-header{font-weight:700}.redux-container-slides .redux_slides_add_remove{margin-bottom:10px}.redux-container-slides input{width:100%!important}.wp-customizer .redux-container-slides .ui-accordion .ui-accordion-content{padding:10px}.redux-container-sortable i.el{cursor:move}.redux-container-sortable label{margin-right:10px;width:300px}.redux-container-sortable label.bugger{margin-bottom:0!important;font-size:12px!important;color:#999}.redux-container-sortable input{margin-right:10px}.redux-container-sortable .checkbox-container{width:364px}.redux-container-sortable .checkbox-container .drag{float:right;margin-left:10px}.redux-container-sortable ul.labeled li{line-height:1.4em!important}.redux-container-sortable li{line-height:30px!important}.redux-container-sortable li.ui-state-highlight{height:30px;width:364px;margin-bottom:13px}.redux-container-sortable li.placeholder{height:30px;margin:10px 0}.wp-customizer .redux-sortable input[type=text]{width:92%}.wp-customizer .redux-sortable i.el{margin-left:5px}.wp-customizer .redux-container-sortable .checkbox-container{width:inherit}.wp-customizer .redux-container-sortable .ui-draggable-handle{margin-left:3%}.redux-container-sorter{margin-right:-20px}.redux-container-sorter ul{background:#F9F9F9;border:1px solid #E3E3E3;min-height:40px;padding:10px 10px 0;width:145px;float:left;margin:0 15px 0 0}.redux-container-sorter ul.filled{opacity:.7;filter:alpha(opacity=70);background:#efecec}.redux-container-sorter ul li{border:1px solid #DFDFDF;cursor:move;font-weight:700;margin-bottom:10px!important;padding:0 10px;height:40px;line-height:40px!important;background-color:#F1F1F1;background-image:-ms-linear-gradient(top,#f9f9f9,#ececec);background-image:-moz-linear-gradient(top,#f9f9f9,#ececec);background-image:-o-linear-gradient(top,#f9f9f9,#ececec);background-image:-webkit-gradient(linear,left top,left bottom,from(#f9f9f9),to(#ececec));background-image:-webkit-linear-gradient(top,#f9f9f9,#ececec);background-image:linear-gradient(top,#f9f9f9,#ececec);overflow:hidden;-webkit-border-radius:3px;-moz-border-radius:3px;border-radius:3px;-moz-box-shadow:inset 0 1px 0 #fff;-webkit-box-shadow:inset 0 1px 0 #fff;box-shadow:inset 0 1px 0 #fff;text-align:center}.redux-container-sorter ul li h3{margin:0 0 10px;text-align:center;color:#777;text-transform:capitalize;word-wrap:break-word}.redux-container-sorter ul li.placeholder{height:40px}.wp-customizer .redux-container-sorter ul{width:85%;margin:0 0 5px}.redux-container-spacing .select_wrapper,.redux-container-spacing select{width:80px!important;float:left}.redux-container-spacing .field-spacing-input{margin-right:10px;margin-bottom:7px}@media screen and (max-width:782px){.redux-container-spacing .field-spacing-input input{display:inline-block!important;width:70px!important}.redux-container-spacing .field-spacing-input .add-on{padding:7px 4px;font-size:16px;line-height:1.5}.redux-container-spacing .select_wrapper{margin-top:6px}}.redux-container-spinner .spinner-wrpr{position:relative;display:block;height:30px;overflow:hidden}.redux-container-spinner .spinner-wrpr .spinner-input{position:relative!important;z-index:1;width:45px!important;height:30px!important;background:#e7e7e7!important;border:1px solid #bfbfbf!important;border-right:0!important;border-left:0!important;-webkit-border-radius:0!important;-moz-border-radius:0!important;border-radius:0!important}.redux-container-spinner .ui-spinner{position:static;display:inline}.redux-container-spinner .ui-spinner-buttons{position:absolute;padding:0}.redux-container-spinner .ui-widget .ui-spinner-button{position:absolute;top:0;padding:0 0 30px;overflow:hidden;cursor:pointer;background:-moz-linear-gradient(#fff,#f3f3f3);background:-o-linear-gradient(#fff,#f3f3f3);background:-webkit-gradient(linear,left top,left bottom,from(#fff),to(#f3f3f3));background:linear-gradient(#fff,#f3f3f3);background-color:#fff;border:none;-webkit-box-shadow:none;-moz-box-shadow:none;box-shadow:none}.redux-container-spinner .ui-spinner-button:hover,.redux-container-spinner .ui-state-hover{background:-moz-linear-gradient(#f3f3f3,#fff);background:-o-linear-gradient(#f3f3f3,#fff);background:-webkit-gradient(linear,left top,left bottom,from(#f3f3f3),to(#fff));background:linear-gradient(#f3f3f3,#fff);background-color:#f3f3f3}.redux-container-spinner .ui-corner-tr,.redux-container-spinner .ui-spinner-button .ui-icon-triangle-1-n{-webkit-border-radius:0 5px 5px 0;-moz-border-radius:0 5px 5px 0;border-radius:0 5px 5px 0}.redux-container-spinner .ui-corner-br,.redux-container-spinner .ui-spinner-button .ui-icon-triangle-1-s{-webkit-border-radius:5px 0 0 5px;-moz-border-radius:5px 0 0 5px;border-radius:5px 0 0 5px}.redux-container-spinner .ui-spinner-button .ui-icon{top:0;display:block;width:28px;height:28px;margin:0;border:1px solid #b7b7b7}.redux-container-spinner .ui-spinner-button .ui-icon-triangle-1-n{background:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAYAAAAKCAYAAACXDi8zAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAADxJREFUeNpsjwsKADAIQu3u3tsRY6M5gz7w0AqSQFLdZ3ZRgmf44JQ/EOZ9oYOsiDviVemP2oYoWCwBBgDpO6VXVo3RyQAAAABJRU5ErkJggg==) 10px 10px no-repeat!important}.redux-container-spinner .ui-spinner-button .ui-icon-triangle-1-s{background:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAYAAAAKCAYAAACXDi8zAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAADhJREFUeNpi+P//PwM6bmlpwS4IorEKokggC8Il0AVhEv9x6sAmiaz9P05XIUsygmVRAUiAESDAAFHcpVdWtdj/AAAAAElFTkSuQmCC) 10px 10px no-repeat!important}.redux-container-switch .cb-disable.selected,.redux-container-switch .cb-enable.selected{color:#fff}.redux-container-switch .switch-options{min-height:30px;margin-right:10px}.redux-container-switch .switch-options label{cursor:pointer}.redux-container-switch .switch-options input{display:none}.redux-container-switch .cb-disable,.redux-container-switch .cb-enable{padding:0 10px;border-width:1px;border-style:solid;-webkit-appearance:none;white-space:nowrap;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box}.redux-container-switch .cb-disable span,.redux-container-switch .cb-enable span{line-height:30px;font-weight:700;-webkit-user-select:none;-khtml-user-select:none;-moz-user-select:none;-o-user-select:none;-ms-user-select:none;user-select:none}.redux-container-switch .cb-disable,.redux-container-switch .cb-disable span,.redux-container-switch .cb-enable,.redux-container-switch .cb-enable span{display:block;float:left}.redux-container-switch .cb-enable{border-right:0;border-radius:3px 0 0 3px;-moz-border-radius:3px 0 0 3px;-webkit-border-radius:3px 0 0 3px}.redux-container-switch .cb-disable{border-left:0;border-radius:0 3px 3px 0;-moz-border-radius:0 3px 3px 0;-webkit-border-radius:0 3px 3px 0}.redux-container-text label{display:block;position:relative;font-size:12px!important;text-align:left;color:#999;margin:4px 0 2px!important;cursor:default;top:5px;width:100px}.redux-container-text input{clear:left}.redux-container-text .input_wrapper{display:block;position:relative;padding:0;width:23%;max-width:23%;min-width:70px;float:left;clear:left;height:57px;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;-o-box-sizing:border-box;box-sizing:border-box;vertical-align:baseline}.wp-customizer .redux-container-text .input_wrapper{width:100%;max-width:100%;height:auto}.redux-main .redux-typography-container{display:block;position:relative;margin:0;padding:0;width:100%;max-width:660px}.redux-main .redux-typography-container .clearfix{clear:both}.redux-main .redux-typography-container .clearfix:after{visibility:hidden;display:block;font-size:0;content:" ";clear:both;height:0}.redux-main .redux-typography-container .redux-typography-color,.redux-main .redux-typography-container input.wp-picker-default{-webkit-box-sizing:border-box;-moz-box-sizing:border-box;-o-box-sizing:border-box;box-sizing:border-box;height:24px;padding:0 14px!important;margin-top:0;margin-bottom:0;margin-left:4px!important;font-size:12px!important}.redux-main .redux-typography-container .select_wrapper{display:block;position:relative;float:left;clear:none;margin:0 10px 0 0;width:48%!important;min-width:210px!important;max-width:324px!important;height:57px;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;-o-box-sizing:border-box;box-sizing:border-box}.redux-main .redux-typography-container .select_wrapper:nth-child(even),.redux-main .redux-typography-container .select_wrapper:nth-child(odd){margin-right:10px!important}.redux-main .redux-typography-container .select_wrapper.typography-family .select2-container{width:100%}.redux-main .redux-typography-container .select_wrapper .redux-typography{font-size:14px!important;display:block;float:left;height:28px!important;line-height:50px!important;padding:0!important;width:100%!important;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;-o-box-sizing:border-box;box-sizing:border-box}.redux-main .redux-typography-container .wp-picker-container{float:left;clear:left;margin-bottom:12px;padding:3px;-webkit-border-radius:3px;-moz-border-radius:3px;border-radius:3px}.redux-main .redux-typography-container .input_wrapper{display:block;position:relative;margin:0 4px 0 5px;padding:0;width:23%;max-width:23%;min-width:70px;float:left;clear:none;height:57px;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;-o-box-sizing:border-box;box-sizing:border-box;vertical-align:baseline}.redux-main .redux-typography-container .input_wrapper.font-size{margin-left:0}.redux-main .redux-typography-container .input_wrapper input.mini{-webkit-box-sizing:border-box;-moz-box-sizing:border-box;-o-box-sizing:border-box;box-sizing:border-box;width:78%;text-align:center;margin:0;height:28px;top:3px;padding:0 2px 0 5px;text-decoration:none;-webkit-border-radius:4px;-moz-border-radius:4px;border-radius:4px}.redux-main .redux-typography-container .picker-wrapper{display:block;position:relative;margin:0;padding:0;width:23%;width:100%;max-width:23%;min-width:70px;min-width:100%;clear:none;height:57px;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;-o-box-sizing:border-box;box-sizing:border-box;vertical-align:baseline}.redux-main .redux-typography-container label{display:block;position:relative;font-size:12px!important;text-align:left;color:#999;margin:4px 0 2px!important;cursor:default}.redux-main .redux-typography-container .typography-preview{display:none;width:100%;border:1px dotted #d3d3d3;max-width:850px;padding:10px;font-size:10pt;height:auto;margin:5px 0 10px;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;overflow:hidden}.redux-main .redux-typography-container .typography-color{border:0;margin:0}.redux-main .redux-typography-container ::-webkit-input-placeholder{line-height:19px}@media screen and (max-width:540px){.redux-main .redux-main .redux-typography-container{max-width:230px;margin:0 auto}.redux-main .redux-main .redux-typography-container .select_wrapper{max-width:210px;min-width:210px;width:210px;margin-left:0!important;margin-right:0!important}.redux-main .redux-main .redux-typography-container .input_wrapper{max-width:101px;min-width:101px;width:101px;margin-left:0!important;margin-right:5px!important}.redux-main .redux-main .redux-typography-container .input_wrapper input.mini{width:73%}.redux-main .redux-main .redux-typography-container .input-append .add-on{width:30%;padding:5px!important}.redux-main .redux-main .redux-main .wp-picker-container .wp-picker-input-wrap{margin-top:7px}}@media screen and (max-width:360px){.redux-main .redux-typography-container .iris-picker .iris-square{margin-right:3%}}.wp-customizer .redux-typography-container .input_wrapper{width:40%;max-width:40%;min-width:20%}.wp-customizer .redux-typography-container .input_wrapper input.mini{width:70%}.wp-customizer .redux-typography-container .select_wrapper{width:100%!important}.redux-main input.redux-color{float:left;width:70px;margin-left:5px}.redux-main input.color-transparency{margin-left:10px;margin-right:3px}.redux-main input.wp-color-picker{width:80px!important}.redux-main .section-color .controls{width:345px}.redux-main .section-color .explain{width:225px}.redux-main .iris-picker .iris-strip .ui-slider-handle{position:absolute;background:0 0!important;right:-3px;left:-3px;border:4px solid #aaa!important;border-width:4px 3px;width:auto;border-radius:4px;box-shadow:0 1px 2px rgba(0,0,0,.2);opacity:.9;z-index:5;cursor:ns-resize}.redux-main .iris-picker .iris-slider-offset{position:absolute;top:2px;left:0;right:0;bottom:4px;width:28px;background:0 0!important;border:0!important;height:auto}.redux-main .wp-picker-container input{margin-bottom:inherit;margin-top:inherit;padding:3px 5px}.redux-main .wp-picker-container .wp-color-result{outline:0;margin:0}.redux-main .wp-picker-container .wp-picker-default{padding:0 10px 1px}.redux-main .redux-color-gradient{line-height:24px}.redux-main .color-transparency-check{line-height:1;margin-top:0!important}.redux-main .wp-picker-clear{margin-top:0!important}.wp-customizer .redux-main .redux-typography-container .redux-typography-color,.wp-customizer .redux-main .redux-typography-container input.wp-picker-default,.wp-customizer .redux-main input.wp-picker-default{padding:0 4px!important}.wp-customizer .redux-main input.wp-color-picker{width:65px!important;margin-left:5px!important}.redux-main .button.remove-image,.redux-main .removeCSS{margin-left:10px;color:#ef521d}.redux-main .button.remove-image:hover,.redux-main .removeCSS:hover{color:red}.redux-main .upload_button_div{margin-bottom:5px}.redux-main .upload-error{float:left;color:#666;font-size:10px;font-weight:700;text-decoration:none;text-shadow:1px 1px 0 #FFF;margin:0 10px 0 0;padding:3px 10px;background:#FFDFEC;-webkit-border-radius:4px;-moz-border-radius:4px;border-radius:4px}.redux-main .reset-button{font-family:Arial,Verdana,sans-serif;float:left;margin:0;color:#ef521d;border-color:#bbb}.redux-main .redux-option-image{max-height:340px;max-width:340px;padding:5px;margin-bottom:0;margin-top:10px;margin-right:15px;border:1px solid #e3e3e3;background:#f7f7f7;-moz-border-radius:3px;-khtml-border-radius:3px;-webkit-border-radius:3px;border-radius:3px}.redux-main .redux-main .upload{width:80%!important}.redux-main .button{margin-top:2px} \ No newline at end of file diff --git a/library/admin/ReduxCore/assets/css/redux-vendor.css b/library/admin/ReduxCore/assets/css/redux-vendor.css deleted file mode 100644 index f0e99d1a..00000000 --- a/library/admin/ReduxCore/assets/css/redux-vendor.css +++ /dev/null @@ -1 +0,0 @@ -.qtip{position:absolute;left:-28000px;top:-28000px;display:none;max-width:280px;min-width:50px;font-size:10.5px;line-height:12px;direction:ltr;box-shadow:none;padding:0}.qtip-content{position:relative;padding:5px 9px;overflow:hidden;text-align:left;word-wrap:break-word}.qtip-titlebar{position:relative;padding:5px 35px 5px 10px;overflow:hidden;border-width:0 0 1px;font-weight:700}.qtip-titlebar+.qtip-content{border-top-width:0!important}.qtip-close{position:absolute;right:-9px;top:-9px;cursor:pointer;outline:0;border-width:1px;border-style:solid;border-color:transparent}.qtip-titlebar .qtip-close{right:4px;top:50%;margin-top:-9px}* html .qtip-titlebar .qtip-close{top:16px}.qtip-icon .ui-icon,.qtip-titlebar .ui-icon{display:block;text-indent:-1000em;direction:ltr}.qtip-icon,.qtip-icon .ui-icon{-moz-border-radius:3px;-webkit-border-radius:3px;border-radius:3px;text-decoration:none}.qtip-icon .ui-icon{width:18px;height:14px;line-height:14px;text-align:center;text-indent:0;font:normal bold 10px/13px Tahoma,sans-serif;color:inherit;background:-100em -100em no-repeat}.qtip-default{border-width:1px;border-style:solid;border-color:#F1D031;background-color:#FFFFA3;color:#555}.qtip-default .qtip-titlebar{background-color:#FFEF93}.qtip-default .qtip-icon{border-color:#CCC;background:#F1F1F1;color:#777}.qtip-default .qtip-titlebar .qtip-close{border-color:#AAA;color:#111}/*! Light tooltip style */.qtip-light{background-color:#fff;border-color:#E2E2E2;color:#454545}.qtip-light .qtip-titlebar{background-color:#f1f1f1}/*! Dark tooltip style */.qtip-dark{background-color:#505050;border-color:#303030;color:#f3f3f3}.qtip-dark .qtip-titlebar{background-color:#404040}.qtip-dark .qtip-icon{border-color:#444}.qtip-dark .qtip-titlebar .ui-state-hover{border-color:#303030}/*! Cream tooltip style */.qtip-cream{background-color:#FBF7AA;border-color:#F9E98E;color:#A27D35}.qtip-cream .qtip-titlebar{background-color:#F0DE7D}.qtip-cream .qtip-close .qtip-icon{background-position:-82px 0}/*! Red tooltip style */.qtip-red{background-color:#F78B83;border-color:#D95252;color:#912323}.qtip-red .qtip-titlebar{background-color:#F06D65}.qtip-red .qtip-close .qtip-icon{background-position:-102px 0}.qtip-red .qtip-icon,.qtip-red .qtip-titlebar .ui-state-hover{border-color:#D95252}/*! Green tooltip style */.qtip-green{background-color:#CAED9E;border-color:#90D93F;color:#3F6219}.qtip-green .qtip-titlebar{background-color:#B0DE78}.qtip-green .qtip-close .qtip-icon{background-position:-42px 0}/*! Blue tooltip style */.qtip-blue{background-color:#E5F6FE;border-color:#ADD9ED;color:#5E99BD}.qtip-blue .qtip-titlebar{background-color:#D0E9F5}.qtip-blue .qtip-close .qtip-icon{background-position:-2px 0}.qtip-shadow{-webkit-box-shadow:1px 1px 3px 1px rgba(0,0,0,.15);-moz-box-shadow:1px 1px 3px 1px rgba(0,0,0,.15);box-shadow:1px 1px 3px 1px rgba(0,0,0,.15)}.qtip-bootstrap,.qtip-rounded,.qtip-tipsy{-moz-border-radius:5px;-webkit-border-radius:5px;border-radius:5px}.qtip-rounded .qtip-titlebar{-moz-border-radius:4px 4px 0 0;-webkit-border-radius:4px 4px 0 0;border-radius:4px 4px 0 0}.qtip-youtube{-moz-border-radius:2px;-webkit-border-radius:2px;border-radius:2px;-webkit-box-shadow:0 0 3px #333;-moz-box-shadow:0 0 3px #333;box-shadow:0 0 3px #333;color:#fff;border-width:0;background:#4A4A4A;background-image:-webkit-gradient(linear,left top,left bottom,color-stop(0,#4A4A4A),color-stop(100%,#000));background-image:-webkit-linear-gradient(top,#4A4A4A 0,#000 100%);background-image:-moz-linear-gradient(top,#4A4A4A 0,#000 100%);background-image:-ms-linear-gradient(top,#4A4A4A 0,#000 100%);background-image:-o-linear-gradient(top,#4A4A4A 0,#000 100%)}.qtip-youtube .qtip-titlebar{background-color:transparent}.qtip-youtube .qtip-content{padding:.75em;font:12px arial,sans-serif;filter:progid:DXImageTransform.Microsoft.Gradient(GradientType=0, StartColorStr=#4a4a4a, EndColorStr=#000000);-ms-filter:"progid:DXImageTransform.Microsoft.Gradient(GradientType=0,StartColorStr=#4a4a4a,EndColorStr=#000000);"}.qtip-youtube .qtip-icon{border-color:#222}.qtip-youtube .qtip-titlebar .ui-state-hover{border-color:#303030}.qtip-jtools{background:#232323;background:rgba(0,0,0,.7);background-image:-webkit-gradient(linear,left top,left bottom,from(#717171),to(#232323));background-image:-moz-linear-gradient(top,#717171,#232323);background-image:-webkit-linear-gradient(top,#717171,#232323);background-image:-ms-linear-gradient(top,#717171,#232323);background-image:-o-linear-gradient(top,#717171,#232323);border:2px solid #ddd;border:2px solid rgba(241,241,241,1);-moz-border-radius:2px;-webkit-border-radius:2px;border-radius:2px;-webkit-box-shadow:0 0 12px #333;-moz-box-shadow:0 0 12px #333;box-shadow:0 0 12px #333}.qtip-jtools .qtip-titlebar{background-color:transparent;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=#717171, endColorstr=#4A4A4A);-ms-filter:"progid:DXImageTransform.Microsoft.gradient(startColorstr=#717171,endColorstr=#4A4A4A)"}.qtip-jtools .qtip-content{filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=#4A4A4A, endColorstr=#232323);-ms-filter:"progid:DXImageTransform.Microsoft.gradient(startColorstr=#4A4A4A,endColorstr=#232323)"}.qtip-jtools .qtip-content,.qtip-jtools .qtip-titlebar{background:0 0;color:#fff;border:0 dashed transparent}.qtip-jtools .qtip-icon{border-color:#555}.qtip-jtools .qtip-titlebar .ui-state-hover{border-color:#333}.qtip-cluetip{-webkit-box-shadow:4px 4px 5px rgba(0,0,0,.4);-moz-box-shadow:4px 4px 5px rgba(0,0,0,.4);box-shadow:4px 4px 5px rgba(0,0,0,.4);background-color:#D9D9C2;color:#111;border:0 dashed transparent}.qtip-cluetip .qtip-titlebar{background-color:#87876A;color:#fff;border:0 dashed transparent}.qtip-cluetip .qtip-icon{border-color:#808064}.qtip-cluetip .qtip-titlebar .ui-state-hover{border-color:#696952;color:#696952}.qtip-tipsy{background:#000;background:rgba(0,0,0,.87);color:#fff;border:0 solid transparent;font-size:11px;font-family:'Lucida Grande',sans-serif;font-weight:700;line-height:16px;text-shadow:0 1px #000}.qtip-tipsy .qtip-titlebar{padding:6px 35px 0 10px;background-color:transparent}.qtip-tipsy .qtip-content{padding:6px 10px}.qtip-tipsy .qtip-icon{border-color:#222;text-shadow:none}.qtip-tipsy .qtip-titlebar .ui-state-hover{border-color:#303030}.qtip-tipped{border:3px solid #959FA9;-moz-border-radius:3px;-webkit-border-radius:3px;border-radius:3px;background-color:#F9F9F9;color:#454545;font-weight:400;font-family:serif}.qtip-tipped .qtip-titlebar{border-bottom-width:0;color:#fff;background:#3A79B8;background-image:-webkit-gradient(linear,left top,left bottom,from(#3A79B8),to(#2E629D));background-image:-webkit-linear-gradient(top,#3A79B8,#2E629D);background-image:-moz-linear-gradient(top,#3A79B8,#2E629D);background-image:-ms-linear-gradient(top,#3A79B8,#2E629D);background-image:-o-linear-gradient(top,#3A79B8,#2E629D);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=#3A79B8, endColorstr=#2E629D);-ms-filter:"progid:DXImageTransform.Microsoft.gradient(startColorstr=#3A79B8,endColorstr=#2E629D)"}.qtip-tipped .qtip-icon{border:2px solid #285589;background:#285589}.qtip-tipped .qtip-icon .ui-icon{background-color:#FBFBFB;color:#555}.qtip-bootstrap{font-size:14px;line-height:20px;color:#333;padding:1px;background-color:#fff;border:1px solid #ccc;border:1px solid rgba(0,0,0,.2);-webkit-border-radius:6px;-moz-border-radius:6px;border-radius:6px;-webkit-box-shadow:0 5px 10px rgba(0,0,0,.2);-moz-box-shadow:0 5px 10px rgba(0,0,0,.2);box-shadow:0 5px 10px rgba(0,0,0,.2);-webkit-background-clip:padding-box;-moz-background-clip:padding;background-clip:padding-box}.qtip-bootstrap .qtip-titlebar{padding:8px 14px;margin:0;font-size:14px;font-weight:400;line-height:18px;background-color:#f7f7f7;border-bottom:1px solid #ebebeb;-webkit-border-radius:5px 5px 0 0;-moz-border-radius:5px 5px 0 0;border-radius:5px 5px 0 0}.qtip-bootstrap .qtip-titlebar .qtip-close{right:11px;top:45%;border-style:none}.qtip-bootstrap .qtip-content{padding:9px 14px}.qtip-bootstrap .qtip-icon{background:0 0}.qtip-bootstrap .qtip-icon .ui-icon{width:auto;height:auto;float:right;font-size:20px;font-weight:700;line-height:18px;color:#000;text-shadow:0 1px 0 #fff;opacity:.2;filter:alpha(opacity=20)}.qtip-bootstrap .qtip-icon .ui-icon:hover{color:#000;text-decoration:none;cursor:pointer;opacity:.4;filter:alpha(opacity=40)}.qtip:not(.ie9haxors) div.qtip-content,.qtip:not(.ie9haxors) div.qtip-titlebar{filter:none;-ms-filter:none}.qtip .qtip-tip{margin:0 auto;overflow:hidden;z-index:10}.qtip .qtip-tip,x:-o-prefocus{visibility:hidden}.qtip .qtip-tip,.qtip .qtip-tip .qtip-vml,.qtip .qtip-tip canvas{position:absolute;color:#123456;background:0 0;border:0 dashed transparent}.qtip .qtip-tip canvas{top:0;left:0}.qtip .qtip-tip .qtip-vml{behavior:url(#default#VML);display:inline-block;visibility:visible}#qtip-overlay{position:fixed;left:0;top:0;width:100%;height:100%}#qtip-overlay.blurs{cursor:pointer}#qtip-overlay div{position:absolute;left:0;top:0;width:100%;height:100%;background-color:#000;opacity:.7;filter:alpha(opacity=70);-ms-filter:"progid:DXImageTransform.Microsoft.Alpha(Opacity=70)"}.qtipmodal-ie6fix{position:absolute!important}.sp-container{position:absolute;top:0;left:0;display:inline-block;z-index:9999994;overflow:hidden}.sp-container.sp-flat{position:relative}.sp-container,.sp-container *{-webkit-box-sizing:content-box;-moz-box-sizing:content-box;box-sizing:content-box}.sp-top{position:relative;width:100%;display:inline-block}.sp-top-inner{position:absolute;top:0;left:0;bottom:0;right:0}.sp-color{position:absolute;top:0;left:0;bottom:0;right:20%}.sp-hue{position:absolute;top:0;right:0;bottom:0;left:84%;height:100%}.sp-clear-enabled .sp-hue{top:33px;height:77.5%}.sp-fill{padding-top:80%}.sp-sat,.sp-val{position:absolute;top:0;left:0;right:0;bottom:0}.sp-alpha-enabled .sp-top{margin-bottom:18px}.sp-alpha-enabled .sp-alpha{display:block}.sp-alpha-handle{position:absolute;top:-4px;bottom:-4px;width:6px;left:50%;cursor:pointer;border:1px solid #000;background:#fff;opacity:.8}.sp-alpha{display:none;bottom:-14px;right:0;left:0;height:8px}.sp-alpha-inner{border:1px solid #333}.sp-clear{display:none}.sp-clear.sp-clear-display{background-position:center}.sp-clear-enabled .sp-clear{display:block;position:absolute;top:0;right:0;bottom:0;left:84%;height:28px}.sp-alpha,.sp-alpha-handle,.sp-clear,.sp-container,.sp-container button,.sp-container.sp-dragging .sp-input,.sp-dragger,.sp-preview,.sp-replacer,.sp-slider{-webkit-user-select:none;-moz-user-select:-moz-none;-o-user-select:none;user-select:none}.sp-container.sp-buttons-disabled .sp-button-container,.sp-container.sp-input-disabled .sp-input-container,.sp-container.sp-palette-buttons-disabled .sp-palette-button-container,.sp-initial-disabled .sp-initial,.sp-palette-disabled .sp-palette-container,.sp-palette-only .sp-picker-container{display:none}.sp-sat{background-image:-webkit-gradient(linear,0 0,100% 0,from(#FFF),to(rgba(204,154,129,0)));background-image:-webkit-linear-gradient(left,#FFF,rgba(204,154,129,0));background-image:-moz-linear-gradient(left,#fff,rgba(204,154,129,0));background-image:-o-linear-gradient(left,#fff,rgba(204,154,129,0));background-image:-ms-linear-gradient(left,#fff,rgba(204,154,129,0));background-image:linear-gradient(to right,#fff,rgba(204,154,129,0));-ms-filter:"progid:DXImageTransform.Microsoft.gradient(GradientType = 1, startColorstr=#FFFFFFFF, endColorstr=#00CC9A81)";filter:progid:DXImageTransform.Microsoft.gradient(GradientType=1, startColorstr='#FFFFFFFF', endColorstr='#00CC9A81')}.sp-val{background-image:-webkit-gradient(linear,0 100%,0 0,from(#000),to(rgba(204,154,129,0)));background-image:-webkit-linear-gradient(bottom,#000,rgba(204,154,129,0));background-image:-moz-linear-gradient(bottom,#000,rgba(204,154,129,0));background-image:-o-linear-gradient(bottom,#000,rgba(204,154,129,0));background-image:-ms-linear-gradient(bottom,#000,rgba(204,154,129,0));background-image:linear-gradient(to top,#000,rgba(204,154,129,0));-ms-filter:"progid:DXImageTransform.Microsoft.gradient(startColorstr=#00CC9A81, endColorstr=#FF000000)";filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#00CC9A81', endColorstr='#FF000000')}.sp-hue{background:-moz-linear-gradient(top,red 0,#ff0 17%,#0f0 33%,#0ff 50%,#00f 67%,#f0f 83%,red 100%);background:-ms-linear-gradient(top,red 0,#ff0 17%,#0f0 33%,#0ff 50%,#00f 67%,#f0f 83%,red 100%);background:-o-linear-gradient(top,red 0,#ff0 17%,#0f0 33%,#0ff 50%,#00f 67%,#f0f 83%,red 100%);background:-webkit-gradient(linear,left top,left bottom,from(red),color-stop(.17,#ff0),color-stop(.33,#0f0),color-stop(.5,#0ff),color-stop(.67,#00f),color-stop(.83,#f0f),to(red));background:-webkit-linear-gradient(top,red 0,#ff0 17%,#0f0 33%,#0ff 50%,#00f 67%,#f0f 83%,red 100%);background:linear-gradient(to bottom,red 0,#ff0 17%,#0f0 33%,#0ff 50%,#00f 67%,#f0f 83%,red 100%)}.sp-1{height:17%;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#ff0000', endColorstr='#ffff00')}.sp-2{height:16%;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffff00', endColorstr='#00ff00')}.sp-3{height:17%;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#00ff00', endColorstr='#00ffff')}.sp-4{height:17%;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#00ffff', endColorstr='#0000ff')}.sp-5{height:16%;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#0000ff', endColorstr='#ff00ff')}.sp-6{height:17%;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#ff00ff', endColorstr='#ff0000')}.sp-hidden{display:none!important}.sp-cf:after,.sp-cf:before{content:"";display:table}.sp-cf:after{clear:both}@media (max-device-width:480px){.sp-color{right:40%}.sp-hue{left:63%}.sp-fill{padding-top:60%}}.sp-dragger{border-radius:5px;height:5px;width:5px;border:1px solid #fff;background:#000;cursor:pointer;position:absolute;top:0;left:0}.sp-slider{position:absolute;top:0;cursor:pointer;height:3px;left:-1px;right:-1px;border:1px solid #000;background:#fff;opacity:.8}.sp-container{border-radius:0;background-color:#ECECEC;border:1px solid #f0c49B;padding:0}.sp-clear,.sp-color,.sp-container,.sp-container button,.sp-container input,.sp-hue{font:400 12px "Lucida Grande","Lucida Sans Unicode","Lucida Sans",Geneva,Verdana,sans-serif;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;-ms-box-sizing:border-box;box-sizing:border-box}.sp-top{margin-bottom:3px}.sp-clear,.sp-color,.sp-hue{border:1px solid #666}.sp-input-container{float:right;width:100px;margin-bottom:4px}.sp-initial-disabled .sp-input-container{width:100%}.sp-input{font-size:12px!important;border:1px inset;padding:4px 5px;margin:0;width:100%;background:0 0;border-radius:3px;color:#222}.sp-input:focus{border:1px solid orange}.sp-input.sp-validation-error{border:1px solid red;background:#fdd}.sp-palette-container,.sp-picker-container{float:left;position:relative;padding:10px 10px 300px;margin-bottom:-290px}.sp-picker-container{width:172px;border-left:solid 1px #fff}.sp-palette-container{border-right:solid 1px #ccc}.sp-palette-only .sp-palette-container{border:0}.sp-palette .sp-thumb-el{display:block;position:relative;float:left;cursor:pointer}.sp-palette .sp-thumb-el.sp-thumb-active,.sp-palette .sp-thumb-el:hover{border-color:orange}.sp-initial{float:left;border:1px solid #333}.sp-initial span{width:30px;height:25px;border:none;display:block;float:left;margin:0}.sp-initial .sp-clear-display{background-position:center}.sp-button-container,.sp-palette-button-container{float:right}.sp-replacer{margin:0;overflow:hidden;cursor:pointer;padding:4px;display:inline-block;border:1px solid #91765d;background:#eee;color:#333;vertical-align:middle}.sp-replacer.sp-active,.sp-replacer:hover{border-color:#F0C49B;color:#111}.sp-replacer.sp-disabled{cursor:default;border-color:silver;color:silver}.sp-dd{padding:2px 0;height:16px;line-height:16px;float:left;font-size:10px}.sp-preview{width:25px;height:20px;border:1px solid #222;margin-right:5px;float:left;z-index:0}.sp-palette{max-width:220px}.sp-palette .sp-thumb-el{width:16px;height:16px;margin:2px 1px;border:1px solid #d0d0d0}.sp-container{padding-bottom:0}.sp-container button{background-color:#eee;background-image:-webkit-linear-gradient(top,#eee,#ccc);background-image:-moz-linear-gradient(top,#eee,#ccc);background-image:-ms-linear-gradient(top,#eee,#ccc);background-image:-o-linear-gradient(top,#eee,#ccc);background-image:linear-gradient(to bottom,#eee,#ccc);border:1px solid #ccc;border-bottom:1px solid #bbb;border-radius:3px;color:#333;font-size:14px;line-height:1;padding:5px 4px;text-align:center;text-shadow:0 1px 0 #eee;vertical-align:middle}.sp-container button:hover{background-color:#ddd;background-image:-webkit-linear-gradient(top,#ddd,#bbb);background-image:-moz-linear-gradient(top,#ddd,#bbb);background-image:-ms-linear-gradient(top,#ddd,#bbb);background-image:-o-linear-gradient(top,#ddd,#bbb);background-image:linear-gradient(to bottom,#ddd,#bbb);border:1px solid #bbb;border-bottom:1px solid #999;cursor:pointer;text-shadow:0 1px 0 #ddd}.sp-container button:active{border:1px solid #aaa;border-bottom:1px solid #888;-webkit-box-shadow:inset 0 0 5px 2px #aaa,0 1px 0 0 #eee;-moz-box-shadow:inset 0 0 5px 2px #aaa,0 1px 0 0 #eee;-ms-box-shadow:inset 0 0 5px 2px #aaa,0 1px 0 0 #eee;-o-box-shadow:inset 0 0 5px 2px #aaa,0 1px 0 0 #eee;box-shadow:inset 0 0 5px 2px #aaa,0 1px 0 0 #eee}.sp-cancel{font-size:11px;color:#d93f3f!important;margin:0 5px 0 0;padding:2px;vertical-align:middle;text-decoration:none}.sp-cancel:hover{color:#d93f3f!important;text-decoration:underline}.sp-palette span.sp-thumb-active,.sp-palette span:hover{border-color:#000}.sp-alpha,.sp-preview,.sp-thumb-el{position:relative;background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAwAAAAMCAIAAADZF8uwAAAAGUlEQVQYV2M4gwH+YwCGIasIUwhT25BVBADtzYNYrHvv4gAAAABJRU5ErkJggg==)}.sp-alpha-inner,.sp-preview-inner,.sp-thumb-inner{display:block;position:absolute;top:0;left:0;bottom:0;right:0}.sp-palette .sp-thumb-inner{background-position:50% 50%;background-repeat:no-repeat}.sp-palette .sp-thumb-light.sp-thumb-active .sp-thumb-inner{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABIAAAASCAYAAABWzo5XAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAIVJREFUeNpiYBhsgJFMffxAXABlN5JruT4Q3wfi/0DsT64h8UD8HmpIPCWG/KemIfOJCUB+Aoacx6EGBZyHBqI+WsDCwuQ9mhxeg2A210Ntfo8klk9sOMijaURm7yc1UP2RNCMbKE9ODK1HM6iegYLkfx8pligC9lCD7KmRof0ZhjQACDAAceovrtpVBRkAAAAASUVORK5CYII=)}.sp-palette .sp-thumb-dark.sp-thumb-active .sp-thumb-inner{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABIAAAASCAYAAABWzo5XAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAAadEVYdFNvZnR3YXJlAFBhaW50Lk5FVCB2My41LjEwMPRyoQAAAMdJREFUOE+tkgsNwzAMRMugEAahEAahEAZhEAqlEAZhEAohEAYh81X2dIm8fKpEspLGvudPOsUYpxE2BIJCroJmEW9qJ+MKaBFhEMNabSy9oIcIPwrB+afvAUFoK4H0tMaQ3XtlrggDhOVVMuT4E5MMG0FBbCEYzjYT7OxLEvIHQLY2zWwQ3D+9luyOQTfKDiFD3iUIfPk8VqrKjgAiSfGFPecrg6HN6m/iBcwiDAo7WiBeawa+Kwh7tZoSCGLMqwlSAzVDhoK+6vH4G0P5wdkAAAAASUVORK5CYII=)}.sp-clear-display{background-repeat:no-repeat;background-position:center;background-image:url(data:image/gif;base64,R0lGODlhFAAUAPcAAAAAAJmZmZ2dnZ6enqKioqOjo6SkpKWlpaampqenp6ioqKmpqaqqqqurq/Hx8fLy8vT09PX19ff39/j4+Pn5+fr6+vv7+wAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAACH5BAEAAP8ALAAAAAAUABQAAAihAP9FoPCvoMGDBy08+EdhQAIJCCMybCDAAYUEARBAlFiQQoMABQhKUJBxY0SPICEYHBnggEmDKAuoPMjS5cGYMxHW3IiT478JJA8M/CjTZ0GgLRekNGpwAsYABHIypcAgQMsITDtWJYBR6NSqMico9cqR6tKfY7GeBCuVwlipDNmefAtTrkSzB1RaIAoXodsABiZAEFB06gIBWC1mLVgBa0AAOw==)}.select2-container{margin:0;position:relative;display:inline-block;zoom:1;vertical-align:middle}.select2-container,.select2-drop,.select2-search,.select2-search input{-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box}.select2-container .select2-choice{display:block;height:26px;padding:0 0 0 8px;overflow:hidden;position:relative;border:1px solid #aaa;white-space:nowrap;line-height:26px;color:#444;text-decoration:none;border-radius:4px;background-clip:padding-box;-webkit-touch-callout:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;background-color:#fff;background-image:-webkit-gradient(linear,left bottom,left top,color-stop(0,#eee),color-stop(.5,#fff));background-image:-webkit-linear-gradient(center bottom,#eee 0,#fff 50%);background-image:-moz-linear-gradient(center bottom,#eee 0,#fff 50%);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffffff', endColorstr='#eeeeee', GradientType=0);background-image:linear-gradient(to top,#eee 0,#fff 50%)}html[dir=rtl] .select2-container .select2-choice{padding:0 8px 0 0}.select2-container.select2-drop-above .select2-choice{border-bottom-color:#aaa;border-radius:0 0 4px 4px;background-image:-webkit-gradient(linear,left bottom,left top,color-stop(0,#eee),color-stop(.9,#fff));background-image:-webkit-linear-gradient(center bottom,#eee 0,#fff 90%);background-image:-moz-linear-gradient(center bottom,#eee 0,#fff 90%);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffffff', endColorstr='#eeeeee', GradientType=0);background-image:linear-gradient(to bottom,#eee 0,#fff 90%)}.select2-container.select2-allowclear .select2-choice .select2-chosen{margin-right:42px}.select2-container .select2-choice>.select2-chosen{margin-right:26px;display:block;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;float:none;width:auto}html[dir=rtl] .select2-container .select2-choice>.select2-chosen{margin-left:26px;margin-right:0}.select2-container .select2-choice abbr{display:none;width:12px;height:12px;position:absolute;right:24px;top:8px;font-size:1px;text-decoration:none;border:0;background:url(select2.png) right top no-repeat;cursor:pointer;outline:0}.select2-container.select2-allowclear .select2-choice abbr{display:inline-block}.select2-container .select2-choice abbr:hover{background-position:right -11px;cursor:pointer}.select2-drop-mask{border:0;margin:0;padding:0;position:fixed;left:0;top:0;min-height:100%;min-width:100%;height:auto;width:auto;opacity:0;z-index:9998;background-color:#fff;filter:alpha(opacity=0)}.select2-drop{width:100%;margin-top:-1px;position:absolute;z-index:9999;top:100%;background:#fff;color:#000;border:1px solid #aaa;border-top:0;border-radius:0 0 4px 4px;-webkit-box-shadow:0 4px 5px rgba(0,0,0,.15);box-shadow:0 4px 5px rgba(0,0,0,.15)}.select2-drop.select2-drop-above{margin-top:1px;border-top:1px solid #aaa;border-bottom:0;border-radius:4px 4px 0 0;-webkit-box-shadow:0 -4px 5px rgba(0,0,0,.15);box-shadow:0 -4px 5px rgba(0,0,0,.15)}.select2-drop-active{border:1px solid #5897fb;border-top:none}.select2-drop.select2-drop-above.select2-drop-active{border-top:1px solid #5897fb}.select2-drop-auto-width{border-top:1px solid #aaa;width:auto}.select2-drop-auto-width .select2-search{padding-top:4px}.select2-container .select2-choice .select2-arrow{display:inline-block;width:18px;height:100%;position:absolute;right:0;top:0;border-left:1px solid #aaa;border-radius:0 4px 4px 0;background:#ccc;background:-webkit-gradient(linear,left bottom,left top,color-stop(0,#ccc),color-stop(.6,#eee)) #ccc;background:-webkit-linear-gradient(center bottom,#ccc 0,#eee 60%) #ccc;background:-moz-linear-gradient(center bottom,#ccc 0,#eee 60%) #ccc;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#eeeeee', endColorstr='#cccccc', GradientType=0);background:linear-gradient(to top,#ccc 0,#eee 60%) #ccc}html[dir=rtl] .select2-container .select2-choice .select2-arrow{left:0;right:auto;border-left:none;border-right:1px solid #aaa;border-radius:4px 0 0 4px}.select2-container .select2-choice .select2-arrow b{display:block;width:100%;height:100%;background:url(select2.png) 0 1px no-repeat}html[dir=rtl] .select2-container .select2-choice .select2-arrow b{background-position:2px 1px}.select2-search{display:inline-block;width:100%;min-height:26px;margin:0;padding-left:4px;padding-right:4px;position:relative;z-index:10000;white-space:nowrap}.select2-search input{width:100%;height:auto!important;min-height:26px;padding:4px 20px 4px 5px;margin:0;outline:0;font-family:sans-serif;font-size:1em;border:1px solid #aaa;border-radius:0;-webkit-box-shadow:none;box-shadow:none;background:url(select2.png) 100% -22px no-repeat #fff;background:url(select2.png) 100% -22px no-repeat,linear-gradient(to bottom,#fff 85%,#eee 99%)}html[dir=rtl] .select2-search input{padding:4px 5px 4px 20px;background:url(select2.png) -37px -22px no-repeat #fff;background:url(select2.png) -37px -22px no-repeat,linear-gradient(to bottom,#fff 85%,#eee 99%)}.select2-drop.select2-drop-above .select2-search input{margin-top:4px}.select2-search input.select2-active{background:url(select2-spinner.gif) 100% no-repeat #fff;background:url(select2-spinner.gif) 100% no-repeat,linear-gradient(to bottom,#fff 85%,#eee 99%)}.select2-container-active .select2-choice,.select2-container-active .select2-choices{border:1px solid #5897fb;outline:0;-webkit-box-shadow:0 0 5px rgba(0,0,0,.3);box-shadow:0 0 5px rgba(0,0,0,.3)}.select2-dropdown-open .select2-choice{border-bottom-color:transparent;-webkit-box-shadow:0 1px 0 #fff inset;box-shadow:0 1px 0 #fff inset;border-bottom-left-radius:0;border-bottom-right-radius:0;background-color:#eee;background-image:-webkit-gradient(linear,left bottom,left top,color-stop(0,#fff),color-stop(.5,#eee));background-image:-webkit-linear-gradient(center bottom,#fff 0,#eee 50%);background-image:-moz-linear-gradient(center bottom,#fff 0,#eee 50%);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#eeeeee', endColorstr='#ffffff', GradientType=0);background-image:linear-gradient(to top,#fff 0,#eee 50%)}.select2-dropdown-open.select2-drop-above .select2-choice,.select2-dropdown-open.select2-drop-above .select2-choices{border:1px solid #5897fb;border-top-color:transparent;background-image:-webkit-gradient(linear,left top,left bottom,color-stop(0,#fff),color-stop(.5,#eee));background-image:-webkit-linear-gradient(center top,#fff 0,#eee 50%);background-image:-moz-linear-gradient(center top,#fff 0,#eee 50%);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#eeeeee', endColorstr='#ffffff', GradientType=0);background-image:linear-gradient(to bottom,#fff 0,#eee 50%)}.select2-dropdown-open .select2-choice .select2-arrow{background:0 0;border-left:none;filter:none}html[dir=rtl] .select2-dropdown-open .select2-choice .select2-arrow{border-right:none}.select2-dropdown-open .select2-choice .select2-arrow b{background-position:-18px 1px}html[dir=rtl] .select2-dropdown-open .select2-choice .select2-arrow b{background-position:-16px 1px}.select2-hidden-accessible{border:0;clip:rect(0 0 0 0);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px}.select2-results{max-height:200px;padding:0 0 0 4px;margin:4px 4px 4px 0;position:relative;overflow-x:hidden;overflow-y:auto;-webkit-tap-highlight-color:transparent}html[dir=rtl] .select2-results{padding:0 4px 0 0;margin:4px 0 4px 4px}.select2-results ul.select2-result-sub{margin:0;padding-left:0}.select2-results li{list-style:none;display:list-item;background-image:none}.select2-results li.select2-result-with-children>.select2-result-label{font-weight:700}.select2-results .select2-result-label{padding:3px 7px 4px;margin:0;cursor:pointer;min-height:1em;-webkit-touch-callout:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.select2-results-dept-1 .select2-result-label{padding-left:20px}.select2-results-dept-2 .select2-result-label{padding-left:40px}.select2-results-dept-3 .select2-result-label{padding-left:60px}.select2-results-dept-4 .select2-result-label{padding-left:80px}.select2-results-dept-5 .select2-result-label{padding-left:100px}.select2-results-dept-6 .select2-result-label{padding-left:110px}.select2-results-dept-7 .select2-result-label{padding-left:120px}.select2-results .select2-highlighted{background:#3875d7;color:#fff}.select2-results li em{background:#feffde;font-style:normal}.select2-results .select2-highlighted em{background:0 0}.select2-results .select2-highlighted ul{background:#fff;color:#000}.select2-results .select2-ajax-error,.select2-results .select2-no-results,.select2-results .select2-searching,.select2-results .select2-selection-limit{background:#f4f4f4;display:list-item;padding-left:5px}.select2-results .select2-disabled.select2-highlighted{color:#666;background:#f4f4f4;display:list-item;cursor:default}.select2-results .select2-disabled{background:#f4f4f4;display:list-item;cursor:default}.select2-results .select2-selected{display:none}.select2-more-results.select2-active{background:url(select2-spinner.gif) 100% no-repeat #f4f4f4}.select2-results .select2-ajax-error{background:rgba(255,50,50,.2)}.select2-more-results{background:#f4f4f4;display:list-item}.select2-container.select2-container-disabled .select2-choice{background-color:#f4f4f4;background-image:none;border:1px solid #ddd;cursor:default}.select2-container.select2-container-disabled .select2-choice .select2-arrow{background-color:#f4f4f4;background-image:none;border-left:0}.select2-container.select2-container-disabled .select2-choice abbr{display:none}.select2-container-multi .select2-choices{height:auto!important;height:1%;margin:0;padding:0 5px 0 0;position:relative;border:1px solid #aaa;cursor:text;overflow:hidden;background-color:#fff;background-image:-webkit-gradient(linear,0 0,0 100%,color-stop(1%,#eee),color-stop(15%,#fff));background-image:-webkit-linear-gradient(top,#eee 1%,#fff 15%);background-image:-moz-linear-gradient(top,#eee 1%,#fff 15%);background-image:linear-gradient(to bottom,#eee 1%,#fff 15%)}html[dir=rtl] .select2-container-multi .select2-choices{padding:0 0 0 5px}.select2-locked{padding:3px 5px!important}.select2-container-multi .select2-choices{min-height:26px}.select2-container-multi.select2-container-active .select2-choices{border:1px solid #5897fb;outline:0;-webkit-box-shadow:0 0 5px rgba(0,0,0,.3);box-shadow:0 0 5px rgba(0,0,0,.3)}.select2-container-multi .select2-choices li{float:left;list-style:none}html[dir=rtl] .select2-container-multi .select2-choices li{float:right}.select2-container-multi .select2-choices .select2-search-field{margin:0;padding:0;white-space:nowrap}.select2-container-multi .select2-choices .select2-search-field input{padding:5px;margin:1px 0;font-family:sans-serif;font-size:100%;color:#666;outline:0;border:0;-webkit-box-shadow:none;box-shadow:none;background:0 0!important}.select2-container-multi .select2-choices .select2-search-field input.select2-active{background:url(select2-spinner.gif) 100% no-repeat #fff!important}.select2-default{color:#999!important}.select2-container-multi .select2-choices .select2-search-choice{padding:3px 5px 3px 18px;margin:3px 0 3px 5px;position:relative;line-height:13px;color:#333;cursor:default;border:1px solid #aaa;border-radius:3px;-webkit-box-shadow:0 0 2px #fff inset,0 1px 0 rgba(0,0,0,.05);box-shadow:0 0 2px #fff inset,0 1px 0 rgba(0,0,0,.05);background-clip:padding-box;-webkit-touch-callout:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;background-color:#e4e4e4;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#eeeeee', endColorstr='#f4f4f4', GradientType=0);background-image:-webkit-gradient(linear,0 0,0 100%,color-stop(20%,#f4f4f4),color-stop(50%,#f0f0f0),color-stop(52%,#e8e8e8),color-stop(100%,#eee));background-image:-webkit-linear-gradient(top,#f4f4f4 20%,#f0f0f0 50%,#e8e8e8 52%,#eee 100%);background-image:-moz-linear-gradient(top,#f4f4f4 20%,#f0f0f0 50%,#e8e8e8 52%,#eee 100%);background-image:linear-gradient(to bottom,#f4f4f4 20%,#f0f0f0 50%,#e8e8e8 52%,#eee 100%)}html[dir=rtl] .select2-container-multi .select2-choices .select2-search-choice{margin:3px 5px 3px 0;padding:3px 18px 3px 5px}.select2-container-multi .select2-choices .select2-search-choice .select2-chosen{cursor:default}.select2-container-multi .select2-choices .select2-search-choice-focus{background:#d4d4d4}.select2-search-choice-close{display:block;width:12px;height:13px;position:absolute;right:3px;top:4px;font-size:1px;outline:0;background:url(select2.png) right top no-repeat}html[dir=rtl] .select2-search-choice-close{right:auto;left:3px}.select2-container-multi .select2-search-choice-close{left:3px}html[dir=rtl] .select2-container-multi .select2-search-choice-close{left:auto;right:2px}.select2-container-multi .select2-choices .select2-search-choice .select2-search-choice-close:hover,.select2-container-multi .select2-choices .select2-search-choice-focus .select2-search-choice-close{background-position:right -11px}.select2-container-multi.select2-container-disabled .select2-choices{background-color:#f4f4f4;background-image:none;border:1px solid #ddd;cursor:default}.select2-container-multi.select2-container-disabled .select2-choices .select2-search-choice{padding:3px 5px;border:1px solid #ddd;background-image:none;background-color:#f4f4f4}.select2-container-multi.select2-container-disabled .select2-choices .select2-search-choice .select2-search-choice-close{display:none;background:0 0}.select2-result-selectable .select2-match,.select2-result-unselectable .select2-match{text-decoration:underline}.select2-offscreen,.select2-offscreen:focus{clip:rect(0 0 0 0)!important;width:1px!important;height:1px!important;border:0!important;margin:0!important;padding:0!important;overflow:hidden!important;position:absolute!important;outline:0!important;left:0!important;top:0!important}.select2-display-none{display:none}.select2-measure-scrollbar{position:absolute;top:-10000px;left:-10000px;width:100px;height:100px;overflow:scroll}@media only screen and (-webkit-min-device-pixel-ratio:1.5),only screen and (min-resolution:2dppx){.select2-container .select2-choice .select2-arrow b,.select2-container .select2-choice abbr,.select2-search input,.select2-search-choice-close{background-image:url(select2x2.png)!important;background-repeat:no-repeat!important;background-size:60px 40px!important}.select2-search input{background-position:100% -21px!important}} \ No newline at end of file diff --git a/library/admin/ReduxCore/assets/css/rtl.css b/library/admin/ReduxCore/assets/css/rtl.css deleted file mode 100644 index dedae3eb..00000000 --- a/library/admin/ReduxCore/assets/css/rtl.css +++ /dev/null @@ -1 +0,0 @@ -.redux-container .redux-action_bar{float:left}.redux-container #expand_options,.redux-sidebar,.cb-enable,.cb-disable,.cb-enable span,.cb-disable span,#redux-footer #redux-share{float:right}.redux-main{border-left:0px;margin-left:0px;border-right:1px solid #d8d8d8;margin-right:201px}.redux-group-tab-link-a{padding-left:0px;padding-right:30px}.redux-group-tab-link-a i{padding-left:10px;padding-right:5px}.redux-group-tab-link-a span.group_title{padding-left:0px;padding-right:30px}.redux-container .expand_options,.redux-sidebar,.cb-enable,.cb-disable,.cb-enable span,.cb-disable span,#redux-footer #redux-share{float:right}.redux_slider{margin-left:0px;margin-right:15px}.redux-action_bar{float:left !important}.expand_options{float:right !important;border:1px solid #f00}.redux_field_th{padding:20px 0 20px 10px !important}.field-desc{text-align:right}.redux-container-ace_editor,.redux-container-border,.redux-container-spacing,.redux-container-dimensions{direction:ltr !important}.redux-container-border .field-border-input,.redux-container-border .redux-color-init,.redux-container-border .redux-border-style,.redux-container-sorter,.redux-container-border,.redux-container-spacing,.redux-container-spacing .field-spacing-input,.redux-container-dimensions .redux-dimensions-container,.redux-container-text label,.redux-container-checkbox input,.typography-font-bar,.typography-style-bar,.redux-color.redux-typography-color,.redux-typography-subsets{float:right !important}.input-append{margin-right:10px;direction:ltr !important}.redux-container-slider,.redux-container-spinner,.redux-container-switch{direction:ltr !important;float:right;margin:0}.redux-main .redux-typography-container .typography-preview{text-align:center !important;direction:ltr !important}.redux-info-field .redux-info-icon{margin-left:15px}#redux-share{float:right !important} diff --git a/library/admin/ReduxCore/assets/css/rtl.scss b/library/admin/ReduxCore/assets/css/rtl.scss deleted file mode 100644 index b7abeb4f..00000000 --- a/library/admin/ReduxCore/assets/css/rtl.scss +++ /dev/null @@ -1,118 +0,0 @@ -.redux-container { - .redux-action_bar { - float: left; - } -} - -.redux-container #expand_options, -.redux-sidebar, -.cb-enable, -.cb-disable, -.cb-enable span, -.cb-disable span, -#redux-footer #redux-share { - float: right; -} - -.redux-main { - border-left: 0px; - margin-left: 0px; - border-right: 1px solid #d8d8d8; - margin-right: 201px; -} - -.redux-group-tab-link-a { - padding-left: 0px; - padding-right: 30px; - - i { - padding-left: 10px; - padding-right: 5px; - } - - span.group_title { - padding-left: 0px; - padding-right: 30px; - } -} - -.redux-container .expand_options, -.redux-sidebar, -.cb-enable, -.cb-disable, -.cb-enable span, -.cb-disable span, -#redux-footer #redux-share{ - float:right; -} - -.redux_slider { - margin-left: 0px; - margin-right: 15px; -} - -.redux-action_bar { - float: left !important; -} - -.expand_options { - float: right !important; - border:1px solid #f00; -} - -.redux_field_th{ - padding:20px 0 20px 10px !important; -} - -.field-desc { - text-align: right; -} - -.redux-container-ace_editor, -.redux-container-border, -.redux-container-spacing, -.redux-container-dimensions { - direction: ltr !important; -} - -.redux-container-border .field-border-input, -.redux-container-border .redux-color-init, -.redux-container-border .redux-border-style, -.redux-container-sorter, -.redux-container-border, -.redux-container-spacing, -.redux-container-spacing .field-spacing-input, -.redux-container-dimensions .redux-dimensions-container, -.redux-container-text label, -.redux-container-checkbox input, -.typography-font-bar, -.typography-style-bar, -.redux-color.redux-typography-color, -.redux-typography-subsets { - float:right !important; -} - -.input-append{ - margin-right:10px; direction:ltr !important; -} - -.redux-container-slider, -.redux-container-spinner, -.redux-container-switch { - direction:ltr !important; - float:right; - margin:0; -} - -.redux-main .redux-typography-container .typography-preview { - text-align: center !important; - direction: ltr !important; -} - -.redux-info-field .redux-info-icon { - margin-left: 15px; -} - -#redux-share { - float:right !important; -} \ No newline at end of file diff --git a/library/admin/ReduxCore/assets/css/vendor/elusive-icons/elusive-icons.css b/library/admin/ReduxCore/assets/css/vendor/elusive-icons/elusive-icons.css deleted file mode 100644 index 7c203980..00000000 --- a/library/admin/ReduxCore/assets/css/vendor/elusive-icons/elusive-icons.css +++ /dev/null @@ -1,4 +0,0 @@ -/*! - * Elusive Icons 2.0.0 by @ReduxFramework - http://elusiveicons.com - @reduxframework - * License - http://elusiveicons.com/license (Font: SIL OFL 1.1, CSS: MIT License) - */@font-face{font-family:'Elusive-Icons';src:url("fonts/elusiveicons-webfont.eot?v=2.0.0");src:url("fonts/elusiveicons-webfont.eot?#iefix&v=2.0.0") format("embedded-opentype"),url("fonts/elusiveicons-webfont.woff?v=2.0.0") format("woff"),url("fonts/elusiveicons-webfont.ttf?v=2.0.0") format("truetype"),url("fonts/elusiveicons-webfont.svg?v=2.0.0#elusiveiconsregular") format("svg");font-weight:normal;font-style:normal}.el{display:inline-block;font:normal normal normal 14px/1 "Elusive-Icons";font-size:inherit;text-rendering:auto;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transform:translate(0, 0)}.el-lg{font-size:1.33333em;line-height:0.75em;vertical-align:-15%}.el-2x{font-size:2em}.el-3x{font-size:3em}.el-4x{font-size:4em}.el-5x{font-size:5em}.el-fw{width:1.28571em;text-align:center}.el-ul{padding-left:0;margin-left:2.14286em;list-style-type:none}.el-ul>li{position:relative}.el-li{position:absolute;left:-2.14286em;width:2.14286em;top:0.14286em;text-align:center}.el-li.el-lg{left:-1.85714em}.el-border{padding:.2em .25em .15em;border:solid 0.08em #eee;border-radius:.1em}.pull-right{float:right}.pull-left{float:left}.el.pull-left{margin-right:.3em}.el.pull-right{margin-left:.3em}.el-spin{-webkit-animation:el-spin 2s infinite linear;animation:el-spin 2s infinite linear}.el-pulse{-webkit-animation:el-spin 1s infinite steps(8);animation:el-spin 1s infinite steps(8)}@-webkit-keyframes el-spin{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg)}100%{-webkit-transform:rotate(359deg);transform:rotate(359deg)}}@keyframes el-spin{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg)}100%{-webkit-transform:rotate(359deg);transform:rotate(359deg)}}.el-rotate-90{filter:progid:DXImageTransform.Microsoft.BasicImage(rotation=1);-webkit-transform:rotate(90deg);-ms-transform:rotate(90deg);transform:rotate(90deg)}.el-rotate-180{filter:progid:DXImageTransform.Microsoft.BasicImage(rotation=2);-webkit-transform:rotate(180deg);-ms-transform:rotate(180deg);transform:rotate(180deg)}.el-rotate-270{filter:progid:DXImageTransform.Microsoft.BasicImage(rotation=3);-webkit-transform:rotate(270deg);-ms-transform:rotate(270deg);transform:rotate(270deg)}.el-flip-horizontal{filter:progid:DXImageTransform.Microsoft.BasicImage(rotation=0);-webkit-transform:scale(-1, 1);-ms-transform:scale(-1, 1);transform:scale(-1, 1)}.el-flip-vertical{filter:progid:DXImageTransform.Microsoft.BasicImage(rotation=2);-webkit-transform:scale(1, -1);-ms-transform:scale(1, -1);transform:scale(1, -1)}:root .el-rotate-90,:root .el-rotate-180,:root .el-rotate-270,:root .el-flip-horizontal,:root .el-flip-vertical{filter:none}.el-stack{position:relative;display:inline-block;width:2em;height:2em;line-height:2em;vertical-align:middle}.el-stack-1x,.el-stack-2x{position:absolute;left:0;width:100%;text-align:center}.el-stack-1x{line-height:inherit}.el-stack-2x{font-size:2em}.el-inverse{color:#fff}.el-icon-address-book-alt:before,.el-address-book-alt:before{content:"ï„"}.el-icon-address-book:before,.el-address-book:before{content:"ï„‚"}.el-icon-adjust-alt:before,.el-adjust-alt:before{content:""}.el-icon-adjust:before,.el-adjust:before{content:"ï„„"}.el-icon-adult:before,.el-adult:before{content:"ï„…"}.el-icon-align-center:before,.el-align-center:before{content:""}.el-icon-align-justify:before,.el-align-justify:before{content:""}.el-icon-align-left:before,.el-align-left:before{content:""}.el-icon-align-right:before,.el-align-right:before{content:""}.el-icon-arrow-down:before,.el-arrow-down:before{content:"ï„Š"}.el-icon-arrow-left:before,.el-arrow-left:before{content:"ï„‹"}.el-icon-arrow-right:before,.el-arrow-right:before{content:"ï„Œ"}.el-icon-arrow-up:before,.el-arrow-up:before{content:"ï„"}.el-icon-asl:before,.el-asl:before{content:"ï„Ž"}.el-icon-asterisk:before,.el-asterisk:before{content:"ï„"}.el-icon-backward:before,.el-backward:before{content:"ï„"}.el-icon-ban-circle:before,.el-ban-circle:before{content:"ï„‘"}.el-icon-barcode:before,.el-barcode:before{content:"ï„’"}.el-icon-behance:before,.el-behance:before{content:"ï„“"}.el-icon-bell:before,.el-bell:before{content:"ï„”"}.el-icon-blind:before,.el-blind:before{content:"ï„•"}.el-icon-blogger:before,.el-blogger:before{content:"ï„–"}.el-icon-bold:before,.el-bold:before{content:"ï„—"}.el-icon-book:before,.el-book:before{content:""}.el-icon-bookmark-empty:before,.el-bookmark-empty:before{content:"ï„™"}.el-icon-bookmark:before,.el-bookmark:before{content:"ï„š"}.el-icon-brackets:before,.el-brackets:before{content:"ï„›"}.el-icon-braille:before,.el-braille:before{content:"ï„œ"}.el-icon-briefcase:before,.el-briefcase:before{content:"ï„"}.el-icon-broom:before,.el-broom:before{content:"ï„ž"}.el-icon-brush:before,.el-brush:before{content:"ï„Ÿ"}.el-icon-bulb:before,.el-bulb:before{content:"ï„ "}.el-icon-bullhorn:before,.el-bullhorn:before{content:"ï„¡"}.el-icon-calendar-sign:before,.el-calendar-sign:before{content:"ï„¢"}.el-icon-calendar:before,.el-calendar:before{content:"ï„£"}.el-icon-camera:before,.el-camera:before{content:""}.el-icon-car:before,.el-car:before{content:"ï„¥"}.el-icon-caret-down:before,.el-caret-down:before{content:""}.el-icon-caret-left:before,.el-caret-left:before{content:""}.el-icon-caret-right:before,.el-caret-right:before{content:""}.el-icon-caret-up:before,.el-caret-up:before{content:"ï„©"}.el-icon-cc:before,.el-cc:before{content:""}.el-icon-certificate:before,.el-certificate:before{content:"ï„«"}.el-icon-check-empty:before,.el-check-empty:before{content:""}.el-icon-check:before,.el-check:before{content:"ï„­"}.el-icon-chevron-down:before,.el-chevron-down:before{content:"ï„®"}.el-icon-chevron-left:before,.el-chevron-left:before{content:""}.el-icon-chevron-right:before,.el-chevron-right:before{content:"ï„°"}.el-icon-chevron-up:before,.el-chevron-up:before{content:""}.el-icon-child:before,.el-child:before{content:""}.el-icon-circle-arrow-down:before,.el-circle-arrow-down:before{content:""}.el-icon-circle-arrow-left:before,.el-circle-arrow-left:before{content:"ï„´"}.el-icon-circle-arrow-right:before,.el-circle-arrow-right:before{content:""}.el-icon-circle-arrow-up:before,.el-circle-arrow-up:before{content:""}.el-icon-cloud-alt:before,.el-cloud-alt:before{content:"ï„·"}.el-icon-cloud:before,.el-cloud:before{content:""}.el-icon-cog-alt:before,.el-cog-alt:before{content:""}.el-icon-cog:before,.el-cog:before{content:""}.el-icon-cogs:before,.el-cogs:before{content:"ï„»"}.el-icon-comment-alt:before,.el-comment-alt:before{content:""}.el-icon-comment:before,.el-comment:before{content:""}.el-icon-compass-alt:before,.el-compass-alt:before{content:""}.el-icon-compass:before,.el-compass:before{content:"ï„¿"}.el-icon-credit-card:before,.el-credit-card:before{content:"ï…€"}.el-icon-css:before,.el-css:before{content:"ï…"}.el-icon-dashboard:before,.el-dashboard:before{content:"ï…‚"}.el-icon-delicious:before,.el-delicious:before{content:"ï…ƒ"}.el-icon-deviantart:before,.el-deviantart:before{content:"ï…„"}.el-icon-digg:before,.el-digg:before{content:"ï……"}.el-icon-download-alt:before,.el-download-alt:before{content:"ï…†"}.el-icon-download:before,.el-download:before{content:"ï…‡"}.el-icon-dribbble:before,.el-dribbble:before{content:"ï…ˆ"}.el-icon-edit:before,.el-edit:before{content:"ï…‰"}.el-icon-eject:before,.el-eject:before{content:"ï…Š"}.el-icon-envelope-alt:before,.el-envelope-alt:before{content:"ï…‹"}.el-icon-envelope:before,.el-envelope:before{content:"ï…Œ"}.el-icon-error-alt:before,.el-error-alt:before{content:"ï…"}.el-icon-error:before,.el-error:before{content:"ï…Ž"}.el-icon-eur:before,.el-eur:before{content:"ï…"}.el-icon-exclamation-sign:before,.el-exclamation-sign:before{content:"ï…"}.el-icon-eye-close:before,.el-eye-close:before{content:"ï…‘"}.el-icon-eye-open:before,.el-eye-open:before{content:"ï…’"}.el-icon-facebook:before,.el-facebook:before{content:"ï…“"}.el-icon-facetime-video:before,.el-facetime-video:before{content:"ï…”"}.el-icon-fast-backward:before,.el-fast-backward:before{content:"ï…•"}.el-icon-fast-forward:before,.el-fast-forward:before{content:"ï…–"}.el-icon-female:before,.el-female:before{content:"ï…—"}.el-icon-file-alt:before,.el-file-alt:before{content:"ï…˜"}.el-icon-file-edit-alt:before,.el-file-edit-alt:before{content:"ï…™"}.el-icon-file-edit:before,.el-file-edit:before{content:"ï…š"}.el-icon-file-new-alt:before,.el-file-new-alt:before{content:"ï…›"}.el-icon-file-new:before,.el-file-new:before{content:"ï…œ"}.el-icon-file:before,.el-file:before{content:"ï…"}.el-icon-film:before,.el-film:before{content:"ï…ž"}.el-icon-filter:before,.el-filter:before{content:"ï…Ÿ"}.el-icon-fire:before,.el-fire:before{content:"ï… "}.el-icon-flag-alt:before,.el-flag-alt:before{content:"ï…¡"}.el-icon-flag:before,.el-flag:before{content:"ï…¢"}.el-icon-flickr:before,.el-flickr:before{content:"ï…£"}.el-icon-folder-close:before,.el-folder-close:before{content:"ï…¤"}.el-icon-folder-open:before,.el-folder-open:before{content:"ï…¥"}.el-icon-folder-sign:before,.el-folder-sign:before{content:"ï…¦"}.el-icon-folder:before,.el-folder:before{content:"ï…§"}.el-icon-font:before,.el-font:before{content:"ï…¨"}.el-icon-fontsize:before,.el-fontsize:before{content:"ï…©"}.el-icon-fork:before,.el-fork:before{content:"ï…ª"}.el-icon-forward-alt:before,.el-forward-alt:before{content:"ï…«"}.el-icon-forward:before,.el-forward:before{content:"ï…¬"}.el-icon-foursquare:before,.el-foursquare:before{content:"ï…­"}.el-icon-friendfeed-rect:before,.el-friendfeed-rect:before{content:"ï…®"}.el-icon-friendfeed:before,.el-friendfeed:before{content:"ï…¯"}.el-icon-fullscreen:before,.el-fullscreen:before{content:"ï…°"}.el-icon-gallery:before,.el-gallery:before{content:"ï…±"}.el-icon-gbp:before,.el-gbp:before{content:"ï…²"}.el-icon-gift:before,.el-gift:before{content:"ï…³"}.el-icon-github-text:before,.el-github-text:before{content:"ï…´"}.el-icon-github:before,.el-github:before{content:"ï…µ"}.el-icon-glass:before,.el-glass:before{content:"ï…¶"}.el-icon-glasses:before,.el-glasses:before{content:"ï…·"}.el-icon-globe-alt:before,.el-globe-alt:before{content:"ï…¸"}.el-icon-globe:before,.el-globe:before{content:"ï…¹"}.el-icon-googleplus:before,.el-googleplus:before{content:"ï…º"}.el-icon-graph-alt:before,.el-graph-alt:before{content:"ï…»"}.el-icon-graph:before,.el-graph:before{content:"ï…¼"}.el-icon-group-alt:before,.el-group-alt:before{content:"ï…½"}.el-icon-group:before,.el-group:before{content:"ï…¾"}.el-icon-guidedog:before,.el-guidedog:before{content:"ï…¿"}.el-icon-hand-down:before,.el-hand-down:before{content:""}.el-icon-hand-left:before,.el-hand-left:before{content:"ï†"}.el-icon-hand-right:before,.el-hand-right:before{content:""}.el-icon-hand-up:before,.el-hand-up:before{content:""}.el-icon-hdd:before,.el-hdd:before{content:""}.el-icon-headphones:before,.el-headphones:before{content:""}.el-icon-hearing-impaired:before,.el-hearing-impaired:before{content:""}.el-icon-heart-alt:before,.el-heart-alt:before{content:""}.el-icon-heart-empty:before,.el-heart-empty:before{content:""}.el-icon-heart:before,.el-heart:before{content:""}.el-icon-home-alt:before,.el-home-alt:before{content:""}.el-icon-home:before,.el-home:before{content:""}.el-icon-hourglass:before,.el-hourglass:before{content:""}.el-icon-idea-alt:before,.el-idea-alt:before{content:"ï†"}.el-icon-idea:before,.el-idea:before{content:""}.el-icon-inbox-alt:before,.el-inbox-alt:before{content:"ï†"}.el-icon-inbox-box:before,.el-inbox-box:before{content:"ï†"}.el-icon-inbox:before,.el-inbox:before{content:""}.el-icon-indent-left:before,.el-indent-left:before{content:""}.el-icon-indent-right:before,.el-indent-right:before{content:""}.el-icon-info-circle:before,.el-info-circle:before{content:""}.el-icon-instagram:before,.el-instagram:before{content:""}.el-icon-iphone-home:before,.el-iphone-home:before{content:""}.el-icon-italic:before,.el-italic:before{content:""}.el-icon-key:before,.el-key:before{content:""}.el-icon-laptop-alt:before,.el-laptop-alt:before{content:""}.el-icon-laptop:before,.el-laptop:before{content:""}.el-icon-lastfm:before,.el-lastfm:before{content:""}.el-icon-leaf:before,.el-leaf:before{content:""}.el-icon-lines:before,.el-lines:before{content:"ï†"}.el-icon-link:before,.el-link:before{content:""}.el-icon-linkedin:before,.el-linkedin:before{content:""}.el-icon-list-alt:before,.el-list-alt:before{content:""}.el-icon-list:before,.el-list:before{content:""}.el-icon-livejournal:before,.el-livejournal:before{content:""}.el-icon-lock-alt:before,.el-lock-alt:before{content:""}.el-icon-lock:before,.el-lock:before{content:""}.el-icon-magic:before,.el-magic:before{content:""}.el-icon-magnet:before,.el-magnet:before{content:""}.el-icon-male:before,.el-male:before{content:""}.el-icon-map-marker-alt:before,.el-map-marker-alt:before{content:""}.el-icon-map-marker:before,.el-map-marker:before{content:""}.el-icon-mic-alt:before,.el-mic-alt:before{content:""}.el-icon-mic:before,.el-mic:before{content:""}.el-icon-minus-sign:before,.el-minus-sign:before{content:""}.el-icon-minus:before,.el-minus:before{content:""}.el-icon-move:before,.el-move:before{content:""}.el-icon-music:before,.el-music:before{content:""}.el-icon-myspace:before,.el-myspace:before{content:""}.el-icon-network:before,.el-network:before{content:""}.el-icon-off:before,.el-off:before{content:""}.el-icon-ok-circle:before,.el-ok-circle:before{content:""}.el-icon-ok-sign:before,.el-ok-sign:before{content:""}.el-icon-ok:before,.el-ok:before{content:""}.el-icon-opensource:before,.el-opensource:before{content:""}.el-icon-paper-clip-alt:before,.el-paper-clip-alt:before{content:""}.el-icon-paper-clip:before,.el-paper-clip:before{content:""}.el-icon-path:before,.el-path:before{content:""}.el-icon-pause-alt:before,.el-pause-alt:before{content:""}.el-icon-pause:before,.el-pause:before{content:""}.el-icon-pencil-alt:before,.el-pencil-alt:before{content:""}.el-icon-pencil:before,.el-pencil:before{content:""}.el-icon-person:before,.el-person:before{content:""}.el-icon-phone-alt:before,.el-phone-alt:before{content:""}.el-icon-phone:before,.el-phone:before{content:""}.el-icon-photo-alt:before,.el-photo-alt:before{content:"ï‡"}.el-icon-photo:before,.el-photo:before{content:""}.el-icon-picasa:before,.el-picasa:before{content:""}.el-icon-picture:before,.el-picture:before{content:""}.el-icon-plane:before,.el-plane:before{content:""}.el-icon-play-alt:before,.el-play-alt:before{content:""}.el-icon-play-circle:before,.el-play-circle:before{content:""}.el-icon-play:before,.el-play:before{content:""}.el-icon-plurk-alt:before,.el-plurk-alt:before{content:""}.el-icon-plurk:before,.el-plurk:before{content:""}.el-icon-plus-sign:before,.el-plus-sign:before{content:""}.el-icon-plus:before,.el-plus:before{content:""}.el-icon-podcast:before,.el-podcast:before{content:"ï‡"}.el-icon-print:before,.el-print:before{content:""}.el-icon-puzzle:before,.el-puzzle:before{content:"ï‡"}.el-icon-qrcode:before,.el-qrcode:before{content:"ï‡"}.el-icon-question-sign:before,.el-question-sign:before{content:""}.el-icon-question:before,.el-question:before{content:""}.el-icon-quote-alt:before,.el-quote-alt:before{content:""}.el-icon-quote-right-alt:before,.el-quote-right-alt:before{content:""}.el-icon-quote-right:before,.el-quote-right:before{content:""}.el-icon-quotes:before,.el-quotes:before{content:""}.el-icon-random:before,.el-random:before{content:""}.el-icon-record:before,.el-record:before{content:""}.el-icon-reddit:before,.el-reddit:before{content:""}.el-icon-redux:before,.el-redux:before{content:""}.el-icon-refresh:before,.el-refresh:before{content:""}.el-icon-remove-circle:before,.el-remove-circle:before{content:""}.el-icon-remove-sign:before,.el-remove-sign:before{content:"ï‡"}.el-icon-remove:before,.el-remove:before{content:""}.el-icon-repeat-alt:before,.el-repeat-alt:before{content:""}.el-icon-repeat:before,.el-repeat:before{content:""}.el-icon-resize-full:before,.el-resize-full:before{content:""}.el-icon-resize-horizontal:before,.el-resize-horizontal:before{content:""}.el-icon-resize-small:before,.el-resize-small:before{content:""}.el-icon-resize-vertical:before,.el-resize-vertical:before{content:""}.el-icon-return-key:before,.el-return-key:before{content:""}.el-icon-retweet:before,.el-retweet:before{content:""}.el-icon-reverse-alt:before,.el-reverse-alt:before{content:""}.el-icon-road:before,.el-road:before{content:""}.el-icon-rss:before,.el-rss:before{content:""}.el-icon-scissors:before,.el-scissors:before{content:""}.el-icon-screen-alt:before,.el-screen-alt:before{content:""}.el-icon-screen:before,.el-screen:before{content:""}.el-icon-screenshot:before,.el-screenshot:before{content:""}.el-icon-search-alt:before,.el-search-alt:before{content:""}.el-icon-search:before,.el-search:before{content:""}.el-icon-share-alt:before,.el-share-alt:before{content:""}.el-icon-share:before,.el-share:before{content:""}.el-icon-shopping-cart-sign:before,.el-shopping-cart-sign:before{content:""}.el-icon-shopping-cart:before,.el-shopping-cart:before{content:""}.el-icon-shortcode:before,.el-shortcode:before{content:""}.el-icon-signal:before,.el-signal:before{content:""}.el-icon-skype:before,.el-skype:before{content:""}.el-icon-slideshare:before,.el-slideshare:before{content:""}.el-icon-smiley-alt:before,.el-smiley-alt:before{content:""}.el-icon-smiley:before,.el-smiley:before{content:""}.el-icon-soundcloud:before,.el-soundcloud:before{content:""}.el-icon-speaker:before,.el-speaker:before{content:""}.el-icon-spotify:before,.el-spotify:before{content:""}.el-icon-stackoverflow:before,.el-stackoverflow:before{content:""}.el-icon-star-alt:before,.el-star-alt:before{content:""}.el-icon-star-empty:before,.el-star-empty:before{content:""}.el-icon-star:before,.el-star:before{content:""}.el-icon-step-backward:before,.el-step-backward:before{content:"ïˆ"}.el-icon-step-forward:before,.el-step-forward:before{content:""}.el-icon-stop-alt:before,.el-stop-alt:before{content:""}.el-icon-stop:before,.el-stop:before{content:""}.el-icon-stumbleupon:before,.el-stumbleupon:before{content:""}.el-icon-tag:before,.el-tag:before{content:""}.el-icon-tags:before,.el-tags:before{content:""}.el-icon-tasks:before,.el-tasks:before{content:""}.el-icon-text-height:before,.el-text-height:before{content:""}.el-icon-text-width:before,.el-text-width:before{content:""}.el-icon-th-large:before,.el-th-large:before{content:""}.el-icon-th-list:before,.el-th-list:before{content:""}.el-icon-th:before,.el-th:before{content:"ïˆ"}.el-icon-thumbs-down:before,.el-thumbs-down:before{content:""}.el-icon-thumbs-up:before,.el-thumbs-up:before{content:"ïˆ"}.el-icon-time-alt:before,.el-time-alt:before{content:"ïˆ"}.el-icon-time:before,.el-time:before{content:""}.el-icon-tint:before,.el-tint:before{content:""}.el-icon-torso:before,.el-torso:before{content:""}.el-icon-trash-alt:before,.el-trash-alt:before{content:""}.el-icon-trash:before,.el-trash:before{content:""}.el-icon-tumblr:before,.el-tumblr:before{content:""}.el-icon-twitter:before,.el-twitter:before{content:""}.el-icon-universal-access:before,.el-universal-access:before{content:""}.el-icon-unlock-alt:before,.el-unlock-alt:before{content:""}.el-icon-unlock:before,.el-unlock:before{content:""}.el-icon-upload:before,.el-upload:before{content:""}.el-icon-usd:before,.el-usd:before{content:""}.el-icon-user:before,.el-user:before{content:"ïˆ"}.el-icon-viadeo:before,.el-viadeo:before{content:""}.el-icon-video-alt:before,.el-video-alt:before{content:""}.el-icon-video-chat:before,.el-video-chat:before{content:""}.el-icon-video:before,.el-video:before{content:""}.el-icon-view-mode:before,.el-view-mode:before{content:""}.el-icon-vimeo:before,.el-vimeo:before{content:""}.el-icon-vkontakte:before,.el-vkontakte:before{content:""}.el-icon-volume-down:before,.el-volume-down:before{content:""}.el-icon-volume-off:before,.el-volume-off:before{content:""}.el-icon-volume-up:before,.el-volume-up:before{content:""}.el-icon-w3c:before,.el-w3c:before{content:""}.el-icon-warning-sign:before,.el-warning-sign:before{content:""}.el-icon-website-alt:before,.el-website-alt:before{content:""}.el-icon-website:before,.el-website:before{content:""}.el-icon-wheelchair:before,.el-wheelchair:before{content:""}.el-icon-wordpress:before,.el-wordpress:before{content:""}.el-icon-wrench-alt:before,.el-wrench-alt:before{content:""}.el-icon-wrench:before,.el-wrench:before{content:""}.el-icon-youtube:before,.el-youtube:before{content:""}.el-icon-zoom-in:before,.el-zoom-in:before{content:""}.el-icon-zoom-out:before,.el-zoom-out:before{content:""} diff --git a/library/admin/ReduxCore/assets/css/vendor/elusive-icons/fonts/elusiveicons-webfont.eot b/library/admin/ReduxCore/assets/css/vendor/elusive-icons/fonts/elusiveicons-webfont.eot deleted file mode 100644 index 0fc2bdf4..00000000 Binary files a/library/admin/ReduxCore/assets/css/vendor/elusive-icons/fonts/elusiveicons-webfont.eot and /dev/null differ diff --git a/library/admin/ReduxCore/assets/css/vendor/elusive-icons/fonts/elusiveicons-webfont.svg b/library/admin/ReduxCore/assets/css/vendor/elusive-icons/fonts/elusiveicons-webfont.svg deleted file mode 100644 index cf60ed2b..00000000 --- a/library/admin/ReduxCore/assets/css/vendor/elusive-icons/fonts/elusiveicons-webfont.svg +++ /dev/null @@ -1,934 +0,0 @@ - - - - -Created by FontForge 20120731 at Tue Feb 24 11:41:15 2015 - By Dovy - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - diff --git a/library/admin/ReduxCore/assets/css/vendor/elusive-icons/fonts/elusiveicons-webfont.ttf b/library/admin/ReduxCore/assets/css/vendor/elusive-icons/fonts/elusiveicons-webfont.ttf deleted file mode 100644 index 7065ca1d..00000000 Binary files a/library/admin/ReduxCore/assets/css/vendor/elusive-icons/fonts/elusiveicons-webfont.ttf and /dev/null differ diff --git a/library/admin/ReduxCore/assets/css/vendor/elusive-icons/fonts/elusiveicons-webfont.woff b/library/admin/ReduxCore/assets/css/vendor/elusive-icons/fonts/elusiveicons-webfont.woff deleted file mode 100644 index ed9f388b..00000000 Binary files a/library/admin/ReduxCore/assets/css/vendor/elusive-icons/fonts/elusiveicons-webfont.woff and /dev/null differ diff --git a/library/admin/ReduxCore/assets/css/vendor/elusive-icons/scss/_animated.scss b/library/admin/ReduxCore/assets/css/vendor/elusive-icons/scss/_animated.scss deleted file mode 100644 index 7661bb0e..00000000 --- a/library/admin/ReduxCore/assets/css/vendor/elusive-icons/scss/_animated.scss +++ /dev/null @@ -1,34 +0,0 @@ -// Spinning Icons -// -------------------------- - -.#{$el-css-prefix}-spin { - -webkit-animation: el-spin 2s infinite linear; - animation: el-spin 2s infinite linear; -} - -.#{$el-css-prefix}-pulse { - -webkit-animation: el-spin 1s infinite steps(8); - animation: el-spin 1s infinite steps(8); -} - -@-webkit-keyframes el-spin { - 0% { - -webkit-transform: rotate(0deg); - transform: rotate(0deg); - } - 100% { - -webkit-transform: rotate(359deg); - transform: rotate(359deg); - } -} - -@keyframes el-spin { - 0% { - -webkit-transform: rotate(0deg); - transform: rotate(0deg); - } - 100% { - -webkit-transform: rotate(359deg); - transform: rotate(359deg); - } -} diff --git a/library/admin/ReduxCore/assets/css/vendor/elusive-icons/scss/_bordered-pulled.scss b/library/admin/ReduxCore/assets/css/vendor/elusive-icons/scss/_bordered-pulled.scss deleted file mode 100644 index c5a0858c..00000000 --- a/library/admin/ReduxCore/assets/css/vendor/elusive-icons/scss/_bordered-pulled.scss +++ /dev/null @@ -1,16 +0,0 @@ -// Bordered & Pulled -// ------------------------- - -.#{$el-css-prefix}-border { - padding: .2em .25em .15em; - border: solid .08em $el-border-color; - border-radius: .1em; -} - -.pull-right { float: right; } -.pull-left { float: left; } - -.#{$el-css-prefix} { - &.pull-left { margin-right: .3em; } - &.pull-right { margin-left: .3em; } -} diff --git a/library/admin/ReduxCore/assets/css/vendor/elusive-icons/scss/_core.scss b/library/admin/ReduxCore/assets/css/vendor/elusive-icons/scss/_core.scss deleted file mode 100644 index e987377a..00000000 --- a/library/admin/ReduxCore/assets/css/vendor/elusive-icons/scss/_core.scss +++ /dev/null @@ -1,13 +0,0 @@ -// Base Class Definition -// ------------------------- - -.#{$el-css-prefix} { - display: inline-block; - font: normal normal normal #{$el-font-size-base}/1 'Elusive-Icons'; // shortening font declaration - font-size: inherit; // can't have font-size inherit on line above, so need to override - text-rendering: auto; // optimizelegibility throws things off #1094 - -webkit-font-smoothing: antialiased; - -moz-osx-font-smoothing: grayscale; - transform: translate(0, 0); // ensures no half-pixel rendering in firefox - -} diff --git a/library/admin/ReduxCore/assets/css/vendor/elusive-icons/scss/_fixed-width.scss b/library/admin/ReduxCore/assets/css/vendor/elusive-icons/scss/_fixed-width.scss deleted file mode 100644 index 04587534..00000000 --- a/library/admin/ReduxCore/assets/css/vendor/elusive-icons/scss/_fixed-width.scss +++ /dev/null @@ -1,6 +0,0 @@ -// Fixed Width Icons -// ------------------------- -.#{$el-css-prefix}-fw { - width: (18em / 14); - text-align: center; -} diff --git a/library/admin/ReduxCore/assets/css/vendor/elusive-icons/scss/_icons.scss b/library/admin/ReduxCore/assets/css/vendor/elusive-icons/scss/_icons.scss deleted file mode 100644 index 6479042e..00000000 --- a/library/admin/ReduxCore/assets/css/vendor/elusive-icons/scss/_icons.scss +++ /dev/null @@ -1,615 +0,0 @@ -/* Elusive Icons uses the Unicode Private Use Area (PUA) to ensure screen - readers do not read off random characters that represent icons */ - -.#{$el-css-prefix}-icon-address-book-alt:before, -.#{$el-css-prefix}-address-book-alt:before { content: $el-var-address-book-alt; } -.#{$el-css-prefix}-icon-address-book:before, -.#{$el-css-prefix}-address-book:before { content: $el-var-address-book; } -.#{$el-css-prefix}-icon-adjust-alt:before, -.#{$el-css-prefix}-adjust-alt:before { content: $el-var-adjust-alt; } -.#{$el-css-prefix}-icon-adjust:before, -.#{$el-css-prefix}-adjust:before { content: $el-var-adjust; } -.#{$el-css-prefix}-icon-adult:before, -.#{$el-css-prefix}-adult:before { content: $el-var-adult; } -.#{$el-css-prefix}-icon-align-center:before, -.#{$el-css-prefix}-align-center:before { content: $el-var-align-center; } -.#{$el-css-prefix}-icon-align-justify:before, -.#{$el-css-prefix}-align-justify:before { content: $el-var-align-justify; } -.#{$el-css-prefix}-icon-align-left:before, -.#{$el-css-prefix}-align-left:before { content: $el-var-align-left; } -.#{$el-css-prefix}-icon-align-right:before, -.#{$el-css-prefix}-align-right:before { content: $el-var-align-right; } -.#{$el-css-prefix}-icon-arrow-down:before, -.#{$el-css-prefix}-arrow-down:before { content: $el-var-arrow-down; } -.#{$el-css-prefix}-icon-arrow-left:before, -.#{$el-css-prefix}-arrow-left:before { content: $el-var-arrow-left; } -.#{$el-css-prefix}-icon-arrow-right:before, -.#{$el-css-prefix}-arrow-right:before { content: $el-var-arrow-right; } -.#{$el-css-prefix}-icon-arrow-up:before, -.#{$el-css-prefix}-arrow-up:before { content: $el-var-arrow-up; } -.#{$el-css-prefix}-icon-asl:before, -.#{$el-css-prefix}-asl:before { content: $el-var-asl; } -.#{$el-css-prefix}-icon-asterisk:before, -.#{$el-css-prefix}-asterisk:before { content: $el-var-asterisk; } -.#{$el-css-prefix}-icon-backward:before, -.#{$el-css-prefix}-backward:before { content: $el-var-backward; } -.#{$el-css-prefix}-icon-ban-circle:before, -.#{$el-css-prefix}-ban-circle:before { content: $el-var-ban-circle; } -.#{$el-css-prefix}-icon-barcode:before, -.#{$el-css-prefix}-barcode:before { content: $el-var-barcode; } -.#{$el-css-prefix}-icon-behance:before, -.#{$el-css-prefix}-behance:before { content: $el-var-behance; } -.#{$el-css-prefix}-icon-bell:before, -.#{$el-css-prefix}-bell:before { content: $el-var-bell; } -.#{$el-css-prefix}-icon-blind:before, -.#{$el-css-prefix}-blind:before { content: $el-var-blind; } -.#{$el-css-prefix}-icon-blogger:before, -.#{$el-css-prefix}-blogger:before { content: $el-var-blogger; } -.#{$el-css-prefix}-icon-bold:before, -.#{$el-css-prefix}-bold:before { content: $el-var-bold; } -.#{$el-css-prefix}-icon-book:before, -.#{$el-css-prefix}-book:before { content: $el-var-book; } -.#{$el-css-prefix}-icon-bookmark-empty:before, -.#{$el-css-prefix}-bookmark-empty:before { content: $el-var-bookmark-empty; } -.#{$el-css-prefix}-icon-bookmark:before, -.#{$el-css-prefix}-bookmark:before { content: $el-var-bookmark; } -.#{$el-css-prefix}-icon-brackets:before, -.#{$el-css-prefix}-brackets:before { content: $el-var-brackets; } -.#{$el-css-prefix}-icon-braille:before, -.#{$el-css-prefix}-braille:before { content: $el-var-braille; } -.#{$el-css-prefix}-icon-briefcase:before, -.#{$el-css-prefix}-briefcase:before { content: $el-var-briefcase; } -.#{$el-css-prefix}-icon-broom:before, -.#{$el-css-prefix}-broom:before { content: $el-var-broom; } -.#{$el-css-prefix}-icon-brush:before, -.#{$el-css-prefix}-brush:before { content: $el-var-brush; } -.#{$el-css-prefix}-icon-bulb:before, -.#{$el-css-prefix}-bulb:before { content: $el-var-bulb; } -.#{$el-css-prefix}-icon-bullhorn:before, -.#{$el-css-prefix}-bullhorn:before { content: $el-var-bullhorn; } -.#{$el-css-prefix}-icon-calendar-sign:before, -.#{$el-css-prefix}-calendar-sign:before { content: $el-var-calendar-sign; } -.#{$el-css-prefix}-icon-calendar:before, -.#{$el-css-prefix}-calendar:before { content: $el-var-calendar; } -.#{$el-css-prefix}-icon-camera:before, -.#{$el-css-prefix}-camera:before { content: $el-var-camera; } -.#{$el-css-prefix}-icon-car:before, -.#{$el-css-prefix}-car:before { content: $el-var-car; } -.#{$el-css-prefix}-icon-caret-down:before, -.#{$el-css-prefix}-caret-down:before { content: $el-var-caret-down; } -.#{$el-css-prefix}-icon-caret-left:before, -.#{$el-css-prefix}-caret-left:before { content: $el-var-caret-left; } -.#{$el-css-prefix}-icon-caret-right:before, -.#{$el-css-prefix}-caret-right:before { content: $el-var-caret-right; } -.#{$el-css-prefix}-icon-caret-up:before, -.#{$el-css-prefix}-caret-up:before { content: $el-var-caret-up; } -.#{$el-css-prefix}-icon-cc:before, -.#{$el-css-prefix}-cc:before { content: $el-var-cc; } -.#{$el-css-prefix}-icon-certificate:before, -.#{$el-css-prefix}-certificate:before { content: $el-var-certificate; } -.#{$el-css-prefix}-icon-check-empty:before, -.#{$el-css-prefix}-check-empty:before { content: $el-var-check-empty; } -.#{$el-css-prefix}-icon-check:before, -.#{$el-css-prefix}-check:before { content: $el-var-check; } -.#{$el-css-prefix}-icon-chevron-down:before, -.#{$el-css-prefix}-chevron-down:before { content: $el-var-chevron-down; } -.#{$el-css-prefix}-icon-chevron-left:before, -.#{$el-css-prefix}-chevron-left:before { content: $el-var-chevron-left; } -.#{$el-css-prefix}-icon-chevron-right:before, -.#{$el-css-prefix}-chevron-right:before { content: $el-var-chevron-right; } -.#{$el-css-prefix}-icon-chevron-up:before, -.#{$el-css-prefix}-chevron-up:before { content: $el-var-chevron-up; } -.#{$el-css-prefix}-icon-child:before, -.#{$el-css-prefix}-child:before { content: $el-var-child; } -.#{$el-css-prefix}-icon-circle-arrow-down:before, -.#{$el-css-prefix}-circle-arrow-down:before { content: $el-var-circle-arrow-down; } -.#{$el-css-prefix}-icon-circle-arrow-left:before, -.#{$el-css-prefix}-circle-arrow-left:before { content: $el-var-circle-arrow-left; } -.#{$el-css-prefix}-icon-circle-arrow-right:before, -.#{$el-css-prefix}-circle-arrow-right:before { content: $el-var-circle-arrow-right; } -.#{$el-css-prefix}-icon-circle-arrow-up:before, -.#{$el-css-prefix}-circle-arrow-up:before { content: $el-var-circle-arrow-up; } -.#{$el-css-prefix}-icon-cloud-alt:before, -.#{$el-css-prefix}-cloud-alt:before { content: $el-var-cloud-alt; } -.#{$el-css-prefix}-icon-cloud:before, -.#{$el-css-prefix}-cloud:before { content: $el-var-cloud; } -.#{$el-css-prefix}-icon-cog-alt:before, -.#{$el-css-prefix}-cog-alt:before { content: $el-var-cog-alt; } -.#{$el-css-prefix}-icon-cog:before, -.#{$el-css-prefix}-cog:before { content: $el-var-cog; } -.#{$el-css-prefix}-icon-cogs:before, -.#{$el-css-prefix}-cogs:before { content: $el-var-cogs; } -.#{$el-css-prefix}-icon-comment-alt:before, -.#{$el-css-prefix}-comment-alt:before { content: $el-var-comment-alt; } -.#{$el-css-prefix}-icon-comment:before, -.#{$el-css-prefix}-comment:before { content: $el-var-comment; } -.#{$el-css-prefix}-icon-compass-alt:before, -.#{$el-css-prefix}-compass-alt:before { content: $el-var-compass-alt; } -.#{$el-css-prefix}-icon-compass:before, -.#{$el-css-prefix}-compass:before { content: $el-var-compass; } -.#{$el-css-prefix}-icon-credit-card:before, -.#{$el-css-prefix}-credit-card:before { content: $el-var-credit-card; } -.#{$el-css-prefix}-icon-css:before, -.#{$el-css-prefix}-css:before { content: $el-var-css; } -.#{$el-css-prefix}-icon-dashboard:before, -.#{$el-css-prefix}-dashboard:before { content: $el-var-dashboard; } -.#{$el-css-prefix}-icon-delicious:before, -.#{$el-css-prefix}-delicious:before { content: $el-var-delicious; } -.#{$el-css-prefix}-icon-deviantart:before, -.#{$el-css-prefix}-deviantart:before { content: $el-var-deviantart; } -.#{$el-css-prefix}-icon-digg:before, -.#{$el-css-prefix}-digg:before { content: $el-var-digg; } -.#{$el-css-prefix}-icon-download-alt:before, -.#{$el-css-prefix}-download-alt:before { content: $el-var-download-alt; } -.#{$el-css-prefix}-icon-download:before, -.#{$el-css-prefix}-download:before { content: $el-var-download; } -.#{$el-css-prefix}-icon-dribbble:before, -.#{$el-css-prefix}-dribbble:before { content: $el-var-dribbble; } -.#{$el-css-prefix}-icon-edit:before, -.#{$el-css-prefix}-edit:before { content: $el-var-edit; } -.#{$el-css-prefix}-icon-eject:before, -.#{$el-css-prefix}-eject:before { content: $el-var-eject; } -.#{$el-css-prefix}-icon-envelope-alt:before, -.#{$el-css-prefix}-envelope-alt:before { content: $el-var-envelope-alt; } -.#{$el-css-prefix}-icon-envelope:before, -.#{$el-css-prefix}-envelope:before { content: $el-var-envelope; } -.#{$el-css-prefix}-icon-error-alt:before, -.#{$el-css-prefix}-error-alt:before { content: $el-var-error-alt; } -.#{$el-css-prefix}-icon-error:before, -.#{$el-css-prefix}-error:before { content: $el-var-error; } -.#{$el-css-prefix}-icon-eur:before, -.#{$el-css-prefix}-eur:before { content: $el-var-eur; } -.#{$el-css-prefix}-icon-exclamation-sign:before, -.#{$el-css-prefix}-exclamation-sign:before { content: $el-var-exclamation-sign; } -.#{$el-css-prefix}-icon-eye-close:before, -.#{$el-css-prefix}-eye-close:before { content: $el-var-eye-close; } -.#{$el-css-prefix}-icon-eye-open:before, -.#{$el-css-prefix}-eye-open:before { content: $el-var-eye-open; } -.#{$el-css-prefix}-icon-facebook:before, -.#{$el-css-prefix}-facebook:before { content: $el-var-facebook; } -.#{$el-css-prefix}-icon-facetime-video:before, -.#{$el-css-prefix}-facetime-video:before { content: $el-var-facetime-video; } -.#{$el-css-prefix}-icon-fast-backward:before, -.#{$el-css-prefix}-fast-backward:before { content: $el-var-fast-backward; } -.#{$el-css-prefix}-icon-fast-forward:before, -.#{$el-css-prefix}-fast-forward:before { content: $el-var-fast-forward; } -.#{$el-css-prefix}-icon-female:before, -.#{$el-css-prefix}-female:before { content: $el-var-female; } -.#{$el-css-prefix}-icon-file-alt:before, -.#{$el-css-prefix}-file-alt:before { content: $el-var-file-alt; } -.#{$el-css-prefix}-icon-file-edit-alt:before, -.#{$el-css-prefix}-file-edit-alt:before { content: $el-var-file-edit-alt; } -.#{$el-css-prefix}-icon-file-edit:before, -.#{$el-css-prefix}-file-edit:before { content: $el-var-file-edit; } -.#{$el-css-prefix}-icon-file-new-alt:before, -.#{$el-css-prefix}-file-new-alt:before { content: $el-var-file-new-alt; } -.#{$el-css-prefix}-icon-file-new:before, -.#{$el-css-prefix}-file-new:before { content: $el-var-file-new; } -.#{$el-css-prefix}-icon-file:before, -.#{$el-css-prefix}-file:before { content: $el-var-file; } -.#{$el-css-prefix}-icon-film:before, -.#{$el-css-prefix}-film:before { content: $el-var-film; } -.#{$el-css-prefix}-icon-filter:before, -.#{$el-css-prefix}-filter:before { content: $el-var-filter; } -.#{$el-css-prefix}-icon-fire:before, -.#{$el-css-prefix}-fire:before { content: $el-var-fire; } -.#{$el-css-prefix}-icon-flag-alt:before, -.#{$el-css-prefix}-flag-alt:before { content: $el-var-flag-alt; } -.#{$el-css-prefix}-icon-flag:before, -.#{$el-css-prefix}-flag:before { content: $el-var-flag; } -.#{$el-css-prefix}-icon-flickr:before, -.#{$el-css-prefix}-flickr:before { content: $el-var-flickr; } -.#{$el-css-prefix}-icon-folder-close:before, -.#{$el-css-prefix}-folder-close:before { content: $el-var-folder-close; } -.#{$el-css-prefix}-icon-folder-open:before, -.#{$el-css-prefix}-folder-open:before { content: $el-var-folder-open; } -.#{$el-css-prefix}-icon-folder-sign:before, -.#{$el-css-prefix}-folder-sign:before { content: $el-var-folder-sign; } -.#{$el-css-prefix}-icon-folder:before, -.#{$el-css-prefix}-folder:before { content: $el-var-folder; } -.#{$el-css-prefix}-icon-font:before, -.#{$el-css-prefix}-font:before { content: $el-var-font; } -.#{$el-css-prefix}-icon-fontsize:before, -.#{$el-css-prefix}-fontsize:before { content: $el-var-fontsize; } -.#{$el-css-prefix}-icon-fork:before, -.#{$el-css-prefix}-fork:before { content: $el-var-fork; } -.#{$el-css-prefix}-icon-forward-alt:before, -.#{$el-css-prefix}-forward-alt:before { content: $el-var-forward-alt; } -.#{$el-css-prefix}-icon-forward:before, -.#{$el-css-prefix}-forward:before { content: $el-var-forward; } -.#{$el-css-prefix}-icon-foursquare:before, -.#{$el-css-prefix}-foursquare:before { content: $el-var-foursquare; } -.#{$el-css-prefix}-icon-friendfeed-rect:before, -.#{$el-css-prefix}-friendfeed-rect:before { content: $el-var-friendfeed-rect; } -.#{$el-css-prefix}-icon-friendfeed:before, -.#{$el-css-prefix}-friendfeed:before { content: $el-var-friendfeed; } -.#{$el-css-prefix}-icon-fullscreen:before, -.#{$el-css-prefix}-fullscreen:before { content: $el-var-fullscreen; } -.#{$el-css-prefix}-icon-gallery:before, -.#{$el-css-prefix}-gallery:before { content: $el-var-gallery; } -.#{$el-css-prefix}-icon-gbp:before, -.#{$el-css-prefix}-gbp:before { content: $el-var-gbp; } -.#{$el-css-prefix}-icon-gift:before, -.#{$el-css-prefix}-gift:before { content: $el-var-gift; } -.#{$el-css-prefix}-icon-github-text:before, -.#{$el-css-prefix}-github-text:before { content: $el-var-github-text; } -.#{$el-css-prefix}-icon-github:before, -.#{$el-css-prefix}-github:before { content: $el-var-github; } -.#{$el-css-prefix}-icon-glass:before, -.#{$el-css-prefix}-glass:before { content: $el-var-glass; } -.#{$el-css-prefix}-icon-glasses:before, -.#{$el-css-prefix}-glasses:before { content: $el-var-glasses; } -.#{$el-css-prefix}-icon-globe-alt:before, -.#{$el-css-prefix}-globe-alt:before { content: $el-var-globe-alt; } -.#{$el-css-prefix}-icon-globe:before, -.#{$el-css-prefix}-globe:before { content: $el-var-globe; } -.#{$el-css-prefix}-icon-googleplus:before, -.#{$el-css-prefix}-googleplus:before { content: $el-var-googleplus; } -.#{$el-css-prefix}-icon-graph-alt:before, -.#{$el-css-prefix}-graph-alt:before { content: $el-var-graph-alt; } -.#{$el-css-prefix}-icon-graph:before, -.#{$el-css-prefix}-graph:before { content: $el-var-graph; } -.#{$el-css-prefix}-icon-group-alt:before, -.#{$el-css-prefix}-group-alt:before { content: $el-var-group-alt; } -.#{$el-css-prefix}-icon-group:before, -.#{$el-css-prefix}-group:before { content: $el-var-group; } -.#{$el-css-prefix}-icon-guidedog:before, -.#{$el-css-prefix}-guidedog:before { content: $el-var-guidedog; } -.#{$el-css-prefix}-icon-hand-down:before, -.#{$el-css-prefix}-hand-down:before { content: $el-var-hand-down; } -.#{$el-css-prefix}-icon-hand-left:before, -.#{$el-css-prefix}-hand-left:before { content: $el-var-hand-left; } -.#{$el-css-prefix}-icon-hand-right:before, -.#{$el-css-prefix}-hand-right:before { content: $el-var-hand-right; } -.#{$el-css-prefix}-icon-hand-up:before, -.#{$el-css-prefix}-hand-up:before { content: $el-var-hand-up; } -.#{$el-css-prefix}-icon-hdd:before, -.#{$el-css-prefix}-hdd:before { content: $el-var-hdd; } -.#{$el-css-prefix}-icon-headphones:before, -.#{$el-css-prefix}-headphones:before { content: $el-var-headphones; } -.#{$el-css-prefix}-icon-hearing-impaired:before, -.#{$el-css-prefix}-hearing-impaired:before { content: $el-var-hearing-impaired; } -.#{$el-css-prefix}-icon-heart-alt:before, -.#{$el-css-prefix}-heart-alt:before { content: $el-var-heart-alt; } -.#{$el-css-prefix}-icon-heart-empty:before, -.#{$el-css-prefix}-heart-empty:before { content: $el-var-heart-empty; } -.#{$el-css-prefix}-icon-heart:before, -.#{$el-css-prefix}-heart:before { content: $el-var-heart; } -.#{$el-css-prefix}-icon-home-alt:before, -.#{$el-css-prefix}-home-alt:before { content: $el-var-home-alt; } -.#{$el-css-prefix}-icon-home:before, -.#{$el-css-prefix}-home:before { content: $el-var-home; } -.#{$el-css-prefix}-icon-hourglass:before, -.#{$el-css-prefix}-hourglass:before { content: $el-var-hourglass; } -.#{$el-css-prefix}-icon-idea-alt:before, -.#{$el-css-prefix}-idea-alt:before { content: $el-var-idea-alt; } -.#{$el-css-prefix}-icon-idea:before, -.#{$el-css-prefix}-idea:before { content: $el-var-idea; } -.#{$el-css-prefix}-icon-inbox-alt:before, -.#{$el-css-prefix}-inbox-alt:before { content: $el-var-inbox-alt; } -.#{$el-css-prefix}-icon-inbox-box:before, -.#{$el-css-prefix}-inbox-box:before { content: $el-var-inbox-box; } -.#{$el-css-prefix}-icon-inbox:before, -.#{$el-css-prefix}-inbox:before { content: $el-var-inbox; } -.#{$el-css-prefix}-icon-indent-left:before, -.#{$el-css-prefix}-indent-left:before { content: $el-var-indent-left; } -.#{$el-css-prefix}-icon-indent-right:before, -.#{$el-css-prefix}-indent-right:before { content: $el-var-indent-right; } -.#{$el-css-prefix}-icon-info-circle:before, -.#{$el-css-prefix}-info-circle:before { content: $el-var-info-circle; } -.#{$el-css-prefix}-icon-instagram:before, -.#{$el-css-prefix}-instagram:before { content: $el-var-instagram; } -.#{$el-css-prefix}-icon-iphone-home:before, -.#{$el-css-prefix}-iphone-home:before { content: $el-var-iphone-home; } -.#{$el-css-prefix}-icon-italic:before, -.#{$el-css-prefix}-italic:before { content: $el-var-italic; } -.#{$el-css-prefix}-icon-key:before, -.#{$el-css-prefix}-key:before { content: $el-var-key; } -.#{$el-css-prefix}-icon-laptop-alt:before, -.#{$el-css-prefix}-laptop-alt:before { content: $el-var-laptop-alt; } -.#{$el-css-prefix}-icon-laptop:before, -.#{$el-css-prefix}-laptop:before { content: $el-var-laptop; } -.#{$el-css-prefix}-icon-lastfm:before, -.#{$el-css-prefix}-lastfm:before { content: $el-var-lastfm; } -.#{$el-css-prefix}-icon-leaf:before, -.#{$el-css-prefix}-leaf:before { content: $el-var-leaf; } -.#{$el-css-prefix}-icon-lines:before, -.#{$el-css-prefix}-lines:before { content: $el-var-lines; } -.#{$el-css-prefix}-icon-link:before, -.#{$el-css-prefix}-link:before { content: $el-var-link; } -.#{$el-css-prefix}-icon-linkedin:before, -.#{$el-css-prefix}-linkedin:before { content: $el-var-linkedin; } -.#{$el-css-prefix}-icon-list-alt:before, -.#{$el-css-prefix}-list-alt:before { content: $el-var-list-alt; } -.#{$el-css-prefix}-icon-list:before, -.#{$el-css-prefix}-list:before { content: $el-var-list; } -.#{$el-css-prefix}-icon-livejournal:before, -.#{$el-css-prefix}-livejournal:before { content: $el-var-livejournal; } -.#{$el-css-prefix}-icon-lock-alt:before, -.#{$el-css-prefix}-lock-alt:before { content: $el-var-lock-alt; } -.#{$el-css-prefix}-icon-lock:before, -.#{$el-css-prefix}-lock:before { content: $el-var-lock; } -.#{$el-css-prefix}-icon-magic:before, -.#{$el-css-prefix}-magic:before { content: $el-var-magic; } -.#{$el-css-prefix}-icon-magnet:before, -.#{$el-css-prefix}-magnet:before { content: $el-var-magnet; } -.#{$el-css-prefix}-icon-male:before, -.#{$el-css-prefix}-male:before { content: $el-var-male; } -.#{$el-css-prefix}-icon-map-marker-alt:before, -.#{$el-css-prefix}-map-marker-alt:before { content: $el-var-map-marker-alt; } -.#{$el-css-prefix}-icon-map-marker:before, -.#{$el-css-prefix}-map-marker:before { content: $el-var-map-marker; } -.#{$el-css-prefix}-icon-mic-alt:before, -.#{$el-css-prefix}-mic-alt:before { content: $el-var-mic-alt; } -.#{$el-css-prefix}-icon-mic:before, -.#{$el-css-prefix}-mic:before { content: $el-var-mic; } -.#{$el-css-prefix}-icon-minus-sign:before, -.#{$el-css-prefix}-minus-sign:before { content: $el-var-minus-sign; } -.#{$el-css-prefix}-icon-minus:before, -.#{$el-css-prefix}-minus:before { content: $el-var-minus; } -.#{$el-css-prefix}-icon-move:before, -.#{$el-css-prefix}-move:before { content: $el-var-move; } -.#{$el-css-prefix}-icon-music:before, -.#{$el-css-prefix}-music:before { content: $el-var-music; } -.#{$el-css-prefix}-icon-myspace:before, -.#{$el-css-prefix}-myspace:before { content: $el-var-myspace; } -.#{$el-css-prefix}-icon-network:before, -.#{$el-css-prefix}-network:before { content: $el-var-network; } -.#{$el-css-prefix}-icon-off:before, -.#{$el-css-prefix}-off:before { content: $el-var-off; } -.#{$el-css-prefix}-icon-ok-circle:before, -.#{$el-css-prefix}-ok-circle:before { content: $el-var-ok-circle; } -.#{$el-css-prefix}-icon-ok-sign:before, -.#{$el-css-prefix}-ok-sign:before { content: $el-var-ok-sign; } -.#{$el-css-prefix}-icon-ok:before, -.#{$el-css-prefix}-ok:before { content: $el-var-ok; } -.#{$el-css-prefix}-icon-opensource:before, -.#{$el-css-prefix}-opensource:before { content: $el-var-opensource; } -.#{$el-css-prefix}-icon-paper-clip-alt:before, -.#{$el-css-prefix}-paper-clip-alt:before { content: $el-var-paper-clip-alt; } -.#{$el-css-prefix}-icon-paper-clip:before, -.#{$el-css-prefix}-paper-clip:before { content: $el-var-paper-clip; } -.#{$el-css-prefix}-icon-path:before, -.#{$el-css-prefix}-path:before { content: $el-var-path; } -.#{$el-css-prefix}-icon-pause-alt:before, -.#{$el-css-prefix}-pause-alt:before { content: $el-var-pause-alt; } -.#{$el-css-prefix}-icon-pause:before, -.#{$el-css-prefix}-pause:before { content: $el-var-pause; } -.#{$el-css-prefix}-icon-pencil-alt:before, -.#{$el-css-prefix}-pencil-alt:before { content: $el-var-pencil-alt; } -.#{$el-css-prefix}-icon-pencil:before, -.#{$el-css-prefix}-pencil:before { content: $el-var-pencil; } -.#{$el-css-prefix}-icon-person:before, -.#{$el-css-prefix}-person:before { content: $el-var-person; } -.#{$el-css-prefix}-icon-phone-alt:before, -.#{$el-css-prefix}-phone-alt:before { content: $el-var-phone-alt; } -.#{$el-css-prefix}-icon-phone:before, -.#{$el-css-prefix}-phone:before { content: $el-var-phone; } -.#{$el-css-prefix}-icon-photo-alt:before, -.#{$el-css-prefix}-photo-alt:before { content: $el-var-photo-alt; } -.#{$el-css-prefix}-icon-photo:before, -.#{$el-css-prefix}-photo:before { content: $el-var-photo; } -.#{$el-css-prefix}-icon-picasa:before, -.#{$el-css-prefix}-picasa:before { content: $el-var-picasa; } -.#{$el-css-prefix}-icon-picture:before, -.#{$el-css-prefix}-picture:before { content: $el-var-picture; } -.#{$el-css-prefix}-icon-plane:before, -.#{$el-css-prefix}-plane:before { content: $el-var-plane; } -.#{$el-css-prefix}-icon-play-alt:before, -.#{$el-css-prefix}-play-alt:before { content: $el-var-play-alt; } -.#{$el-css-prefix}-icon-play-circle:before, -.#{$el-css-prefix}-play-circle:before { content: $el-var-play-circle; } -.#{$el-css-prefix}-icon-play:before, -.#{$el-css-prefix}-play:before { content: $el-var-play; } -.#{$el-css-prefix}-icon-plurk-alt:before, -.#{$el-css-prefix}-plurk-alt:before { content: $el-var-plurk-alt; } -.#{$el-css-prefix}-icon-plurk:before, -.#{$el-css-prefix}-plurk:before { content: $el-var-plurk; } -.#{$el-css-prefix}-icon-plus-sign:before, -.#{$el-css-prefix}-plus-sign:before { content: $el-var-plus-sign; } -.#{$el-css-prefix}-icon-plus:before, -.#{$el-css-prefix}-plus:before { content: $el-var-plus; } -.#{$el-css-prefix}-icon-podcast:before, -.#{$el-css-prefix}-podcast:before { content: $el-var-podcast; } -.#{$el-css-prefix}-icon-print:before, -.#{$el-css-prefix}-print:before { content: $el-var-print; } -.#{$el-css-prefix}-icon-puzzle:before, -.#{$el-css-prefix}-puzzle:before { content: $el-var-puzzle; } -.#{$el-css-prefix}-icon-qrcode:before, -.#{$el-css-prefix}-qrcode:before { content: $el-var-qrcode; } -.#{$el-css-prefix}-icon-question-sign:before, -.#{$el-css-prefix}-question-sign:before { content: $el-var-question-sign; } -.#{$el-css-prefix}-icon-question:before, -.#{$el-css-prefix}-question:before { content: $el-var-question; } -.#{$el-css-prefix}-icon-quote-alt:before, -.#{$el-css-prefix}-quote-alt:before { content: $el-var-quote-alt; } -.#{$el-css-prefix}-icon-quote-right-alt:before, -.#{$el-css-prefix}-quote-right-alt:before { content: $el-var-quote-right-alt; } -.#{$el-css-prefix}-icon-quote-right:before, -.#{$el-css-prefix}-quote-right:before { content: $el-var-quote-right; } -.#{$el-css-prefix}-icon-quotes:before, -.#{$el-css-prefix}-quotes:before { content: $el-var-quotes; } -.#{$el-css-prefix}-icon-random:before, -.#{$el-css-prefix}-random:before { content: $el-var-random; } -.#{$el-css-prefix}-icon-record:before, -.#{$el-css-prefix}-record:before { content: $el-var-record; } -.#{$el-css-prefix}-icon-reddit:before, -.#{$el-css-prefix}-reddit:before { content: $el-var-reddit; } -.#{$el-css-prefix}-icon-redux:before, -.#{$el-css-prefix}-redux:before { content: $el-var-redux; } -.#{$el-css-prefix}-icon-refresh:before, -.#{$el-css-prefix}-refresh:before { content: $el-var-refresh; } -.#{$el-css-prefix}-icon-remove-circle:before, -.#{$el-css-prefix}-remove-circle:before { content: $el-var-remove-circle; } -.#{$el-css-prefix}-icon-remove-sign:before, -.#{$el-css-prefix}-remove-sign:before { content: $el-var-remove-sign; } -.#{$el-css-prefix}-icon-remove:before, -.#{$el-css-prefix}-remove:before { content: $el-var-remove; } -.#{$el-css-prefix}-icon-repeat-alt:before, -.#{$el-css-prefix}-repeat-alt:before { content: $el-var-repeat-alt; } -.#{$el-css-prefix}-icon-repeat:before, -.#{$el-css-prefix}-repeat:before { content: $el-var-repeat; } -.#{$el-css-prefix}-icon-resize-full:before, -.#{$el-css-prefix}-resize-full:before { content: $el-var-resize-full; } -.#{$el-css-prefix}-icon-resize-horizontal:before, -.#{$el-css-prefix}-resize-horizontal:before { content: $el-var-resize-horizontal; } -.#{$el-css-prefix}-icon-resize-small:before, -.#{$el-css-prefix}-resize-small:before { content: $el-var-resize-small; } -.#{$el-css-prefix}-icon-resize-vertical:before, -.#{$el-css-prefix}-resize-vertical:before { content: $el-var-resize-vertical; } -.#{$el-css-prefix}-icon-return-key:before, -.#{$el-css-prefix}-return-key:before { content: $el-var-return-key; } -.#{$el-css-prefix}-icon-retweet:before, -.#{$el-css-prefix}-retweet:before { content: $el-var-retweet; } -.#{$el-css-prefix}-icon-reverse-alt:before, -.#{$el-css-prefix}-reverse-alt:before { content: $el-var-reverse-alt; } -.#{$el-css-prefix}-icon-road:before, -.#{$el-css-prefix}-road:before { content: $el-var-road; } -.#{$el-css-prefix}-icon-rss:before, -.#{$el-css-prefix}-rss:before { content: $el-var-rss; } -.#{$el-css-prefix}-icon-scissors:before, -.#{$el-css-prefix}-scissors:before { content: $el-var-scissors; } -.#{$el-css-prefix}-icon-screen-alt:before, -.#{$el-css-prefix}-screen-alt:before { content: $el-var-screen-alt; } -.#{$el-css-prefix}-icon-screen:before, -.#{$el-css-prefix}-screen:before { content: $el-var-screen; } -.#{$el-css-prefix}-icon-screenshot:before, -.#{$el-css-prefix}-screenshot:before { content: $el-var-screenshot; } -.#{$el-css-prefix}-icon-search-alt:before, -.#{$el-css-prefix}-search-alt:before { content: $el-var-search-alt; } -.#{$el-css-prefix}-icon-search:before, -.#{$el-css-prefix}-search:before { content: $el-var-search; } -.#{$el-css-prefix}-icon-share-alt:before, -.#{$el-css-prefix}-share-alt:before { content: $el-var-share-alt; } -.#{$el-css-prefix}-icon-share:before, -.#{$el-css-prefix}-share:before { content: $el-var-share; } -.#{$el-css-prefix}-icon-shopping-cart-sign:before, -.#{$el-css-prefix}-shopping-cart-sign:before { content: $el-var-shopping-cart-sign; } -.#{$el-css-prefix}-icon-shopping-cart:before, -.#{$el-css-prefix}-shopping-cart:before { content: $el-var-shopping-cart; } -.#{$el-css-prefix}-icon-shortcode:before, -.#{$el-css-prefix}-shortcode:before { content: $el-var-shortcode; } -.#{$el-css-prefix}-icon-signal:before, -.#{$el-css-prefix}-signal:before { content: $el-var-signal; } -.#{$el-css-prefix}-icon-skype:before, -.#{$el-css-prefix}-skype:before { content: $el-var-skype; } -.#{$el-css-prefix}-icon-slideshare:before, -.#{$el-css-prefix}-slideshare:before { content: $el-var-slideshare; } -.#{$el-css-prefix}-icon-smiley-alt:before, -.#{$el-css-prefix}-smiley-alt:before { content: $el-var-smiley-alt; } -.#{$el-css-prefix}-icon-smiley:before, -.#{$el-css-prefix}-smiley:before { content: $el-var-smiley; } -.#{$el-css-prefix}-icon-soundcloud:before, -.#{$el-css-prefix}-soundcloud:before { content: $el-var-soundcloud; } -.#{$el-css-prefix}-icon-speaker:before, -.#{$el-css-prefix}-speaker:before { content: $el-var-speaker; } -.#{$el-css-prefix}-icon-spotify:before, -.#{$el-css-prefix}-spotify:before { content: $el-var-spotify; } -.#{$el-css-prefix}-icon-stackoverflow:before, -.#{$el-css-prefix}-stackoverflow:before { content: $el-var-stackoverflow; } -.#{$el-css-prefix}-icon-star-alt:before, -.#{$el-css-prefix}-star-alt:before { content: $el-var-star-alt; } -.#{$el-css-prefix}-icon-star-empty:before, -.#{$el-css-prefix}-star-empty:before { content: $el-var-star-empty; } -.#{$el-css-prefix}-icon-star:before, -.#{$el-css-prefix}-star:before { content: $el-var-star; } -.#{$el-css-prefix}-icon-step-backward:before, -.#{$el-css-prefix}-step-backward:before { content: $el-var-step-backward; } -.#{$el-css-prefix}-icon-step-forward:before, -.#{$el-css-prefix}-step-forward:before { content: $el-var-step-forward; } -.#{$el-css-prefix}-icon-stop-alt:before, -.#{$el-css-prefix}-stop-alt:before { content: $el-var-stop-alt; } -.#{$el-css-prefix}-icon-stop:before, -.#{$el-css-prefix}-stop:before { content: $el-var-stop; } -.#{$el-css-prefix}-icon-stumbleupon:before, -.#{$el-css-prefix}-stumbleupon:before { content: $el-var-stumbleupon; } -.#{$el-css-prefix}-icon-tag:before, -.#{$el-css-prefix}-tag:before { content: $el-var-tag; } -.#{$el-css-prefix}-icon-tags:before, -.#{$el-css-prefix}-tags:before { content: $el-var-tags; } -.#{$el-css-prefix}-icon-tasks:before, -.#{$el-css-prefix}-tasks:before { content: $el-var-tasks; } -.#{$el-css-prefix}-icon-text-height:before, -.#{$el-css-prefix}-text-height:before { content: $el-var-text-height; } -.#{$el-css-prefix}-icon-text-width:before, -.#{$el-css-prefix}-text-width:before { content: $el-var-text-width; } -.#{$el-css-prefix}-icon-th-large:before, -.#{$el-css-prefix}-th-large:before { content: $el-var-th-large; } -.#{$el-css-prefix}-icon-th-list:before, -.#{$el-css-prefix}-th-list:before { content: $el-var-th-list; } -.#{$el-css-prefix}-icon-th:before, -.#{$el-css-prefix}-th:before { content: $el-var-th; } -.#{$el-css-prefix}-icon-thumbs-down:before, -.#{$el-css-prefix}-thumbs-down:before { content: $el-var-thumbs-down; } -.#{$el-css-prefix}-icon-thumbs-up:before, -.#{$el-css-prefix}-thumbs-up:before { content: $el-var-thumbs-up; } -.#{$el-css-prefix}-icon-time-alt:before, -.#{$el-css-prefix}-time-alt:before { content: $el-var-time-alt; } -.#{$el-css-prefix}-icon-time:before, -.#{$el-css-prefix}-time:before { content: $el-var-time; } -.#{$el-css-prefix}-icon-tint:before, -.#{$el-css-prefix}-tint:before { content: $el-var-tint; } -.#{$el-css-prefix}-icon-torso:before, -.#{$el-css-prefix}-torso:before { content: $el-var-torso; } -.#{$el-css-prefix}-icon-trash-alt:before, -.#{$el-css-prefix}-trash-alt:before { content: $el-var-trash-alt; } -.#{$el-css-prefix}-icon-trash:before, -.#{$el-css-prefix}-trash:before { content: $el-var-trash; } -.#{$el-css-prefix}-icon-tumblr:before, -.#{$el-css-prefix}-tumblr:before { content: $el-var-tumblr; } -.#{$el-css-prefix}-icon-twitter:before, -.#{$el-css-prefix}-twitter:before { content: $el-var-twitter; } -.#{$el-css-prefix}-icon-universal-access:before, -.#{$el-css-prefix}-universal-access:before { content: $el-var-universal-access; } -.#{$el-css-prefix}-icon-unlock-alt:before, -.#{$el-css-prefix}-unlock-alt:before { content: $el-var-unlock-alt; } -.#{$el-css-prefix}-icon-unlock:before, -.#{$el-css-prefix}-unlock:before { content: $el-var-unlock; } -.#{$el-css-prefix}-icon-upload:before, -.#{$el-css-prefix}-upload:before { content: $el-var-upload; } -.#{$el-css-prefix}-icon-usd:before, -.#{$el-css-prefix}-usd:before { content: $el-var-usd; } -.#{$el-css-prefix}-icon-user:before, -.#{$el-css-prefix}-user:before { content: $el-var-user; } -.#{$el-css-prefix}-icon-viadeo:before, -.#{$el-css-prefix}-viadeo:before { content: $el-var-viadeo; } -.#{$el-css-prefix}-icon-video-alt:before, -.#{$el-css-prefix}-video-alt:before { content: $el-var-video-alt; } -.#{$el-css-prefix}-icon-video-chat:before, -.#{$el-css-prefix}-video-chat:before { content: $el-var-video-chat; } -.#{$el-css-prefix}-icon-video:before, -.#{$el-css-prefix}-video:before { content: $el-var-video; } -.#{$el-css-prefix}-icon-view-mode:before, -.#{$el-css-prefix}-view-mode:before { content: $el-var-view-mode; } -.#{$el-css-prefix}-icon-vimeo:before, -.#{$el-css-prefix}-vimeo:before { content: $el-var-vimeo; } -.#{$el-css-prefix}-icon-vkontakte:before, -.#{$el-css-prefix}-vkontakte:before { content: $el-var-vkontakte; } -.#{$el-css-prefix}-icon-volume-down:before, -.#{$el-css-prefix}-volume-down:before { content: $el-var-volume-down; } -.#{$el-css-prefix}-icon-volume-off:before, -.#{$el-css-prefix}-volume-off:before { content: $el-var-volume-off; } -.#{$el-css-prefix}-icon-volume-up:before, -.#{$el-css-prefix}-volume-up:before { content: $el-var-volume-up; } -.#{$el-css-prefix}-icon-w3c:before, -.#{$el-css-prefix}-w3c:before { content: $el-var-w3c; } -.#{$el-css-prefix}-icon-warning-sign:before, -.#{$el-css-prefix}-warning-sign:before { content: $el-var-warning-sign; } -.#{$el-css-prefix}-icon-website-alt:before, -.#{$el-css-prefix}-website-alt:before { content: $el-var-website-alt; } -.#{$el-css-prefix}-icon-website:before, -.#{$el-css-prefix}-website:before { content: $el-var-website; } -.#{$el-css-prefix}-icon-wheelchair:before, -.#{$el-css-prefix}-wheelchair:before { content: $el-var-wheelchair; } -.#{$el-css-prefix}-icon-wordpress:before, -.#{$el-css-prefix}-wordpress:before { content: $el-var-wordpress; } -.#{$el-css-prefix}-icon-wrench-alt:before, -.#{$el-css-prefix}-wrench-alt:before { content: $el-var-wrench-alt; } -.#{$el-css-prefix}-icon-wrench:before, -.#{$el-css-prefix}-wrench:before { content: $el-var-wrench; } -.#{$el-css-prefix}-icon-youtube:before, -.#{$el-css-prefix}-youtube:before { content: $el-var-youtube; } -.#{$el-css-prefix}-icon-zoom-in:before, -.#{$el-css-prefix}-zoom-in:before { content: $el-var-zoom-in; } -.#{$el-css-prefix}-icon-zoom-out:before, -.#{$el-css-prefix}-zoom-out:before { content: $el-var-zoom-out; } diff --git a/library/admin/ReduxCore/assets/css/vendor/elusive-icons/scss/_larger.scss b/library/admin/ReduxCore/assets/css/vendor/elusive-icons/scss/_larger.scss deleted file mode 100644 index f76eab77..00000000 --- a/library/admin/ReduxCore/assets/css/vendor/elusive-icons/scss/_larger.scss +++ /dev/null @@ -1,13 +0,0 @@ -// Icon Sizes -// ------------------------- - -/* makes the font 33% larger relative to the icon container */ -.#{$el-css-prefix}-lg { - font-size: (4em / 3); - line-height: (3em / 4); - vertical-align: -15%; -} -.#{$el-css-prefix}-2x { font-size: 2em; } -.#{$el-css-prefix}-3x { font-size: 3em; } -.#{$el-css-prefix}-4x { font-size: 4em; } -.#{$el-css-prefix}-5x { font-size: 5em; } diff --git a/library/admin/ReduxCore/assets/css/vendor/elusive-icons/scss/_list.scss b/library/admin/ReduxCore/assets/css/vendor/elusive-icons/scss/_list.scss deleted file mode 100644 index fefec82a..00000000 --- a/library/admin/ReduxCore/assets/css/vendor/elusive-icons/scss/_list.scss +++ /dev/null @@ -1,19 +0,0 @@ -// List Icons -// ------------------------- - -.#{$el-css-prefix}-ul { - padding-left: 0; - margin-left: $el-li-width; - list-style-type: none; - > li { position: relative; } -} -.#{$el-css-prefix}-li { - position: absolute; - left: -$el-li-width; - width: $el-li-width; - top: (2em / 14); - text-align: center; - &.#{$el-css-prefix}-lg { - left: -$el-li-width + (4em / 14); - } -} diff --git a/library/admin/ReduxCore/assets/css/vendor/elusive-icons/scss/_mixins.scss b/library/admin/ReduxCore/assets/css/vendor/elusive-icons/scss/_mixins.scss deleted file mode 100644 index b443823f..00000000 --- a/library/admin/ReduxCore/assets/css/vendor/elusive-icons/scss/_mixins.scss +++ /dev/null @@ -1,27 +0,0 @@ -// Mixins -// -------------------------- - -@mixin el-icon() { - display: inline-block; - font: normal normal normal #{$el-font-size-base}/1 'Elusive-Icons'; // shortening font declaration - font-size: inherit; // can't have font-size inherit on line above, so need to override - text-rendering: auto; // optimizelegibility throws things off #1094 - -webkit-font-smoothing: antialiased; - -moz-osx-font-smoothing: grayscale; - transform: translate(0, 0); // ensures no half-pixel rendering in firefox - -} - -@mixin el-icon-rotate($degrees, $rotation) { - filter: progid:DXImageTransform.Microsoft.BasicImage(rotation=#{$rotation}); - -webkit-transform: rotate($degrees); - -ms-transform: rotate($degrees); - transform: rotate($degrees); -} - -@mixin el-icon-flip($horiz, $vert, $rotation) { - filter: progid:DXImageTransform.Microsoft.BasicImage(rotation=#{$rotation}); - -webkit-transform: scale($horiz, $vert); - -ms-transform: scale($horiz, $vert); - transform: scale($horiz, $vert); -} diff --git a/library/admin/ReduxCore/assets/css/vendor/elusive-icons/scss/_path.scss b/library/admin/ReduxCore/assets/css/vendor/elusive-icons/scss/_path.scss deleted file mode 100644 index 4989ef2d..00000000 --- a/library/admin/ReduxCore/assets/css/vendor/elusive-icons/scss/_path.scss +++ /dev/null @@ -1,14 +0,0 @@ -/* FONT PATH - * -------------------------- */ - -@font-face { - font-family: 'Elusive-Icons'; - src: url('#{$el-font-path}/elusiveicons-webfont.eot?v=#{$el-version}'); - src: url('#{$el-font-path}/elusiveicons-webfont.eot?#iefix&v=#{$el-version}') format('embedded-opentype'), - //url('#{$el-font-path}/elusiveicons-webfont.woff2?v=#{$el-version}') format('woff2'), - url('#{$el-font-path}/elusiveicons-webfont.woff?v=#{$el-version}') format('woff'), - url('#{$el-font-path}/elusiveicons-webfont.ttf?v=#{$el-version}') format('truetype'), - url('#{$el-font-path}/elusiveicons-webfont.svg?v=#{$el-version}#elusiveiconsregular') format('svg'); - font-weight: normal; - font-style: normal; -} diff --git a/library/admin/ReduxCore/assets/css/vendor/elusive-icons/scss/_rotated-flipped.scss b/library/admin/ReduxCore/assets/css/vendor/elusive-icons/scss/_rotated-flipped.scss deleted file mode 100644 index 82481611..00000000 --- a/library/admin/ReduxCore/assets/css/vendor/elusive-icons/scss/_rotated-flipped.scss +++ /dev/null @@ -1,20 +0,0 @@ -// Rotated & Flipped Icons -// ------------------------- - -.#{$el-css-prefix}-rotate-90 { @include el-icon-rotate(90deg, 1); } -.#{$el-css-prefix}-rotate-180 { @include el-icon-rotate(180deg, 2); } -.#{$el-css-prefix}-rotate-270 { @include el-icon-rotate(270deg, 3); } - -.#{$el-css-prefix}-flip-horizontal { @include el-icon-flip(-1, 1, 0); } -.#{$el-css-prefix}-flip-vertical { @include el-icon-flip(1, -1, 2); } - -// Hook for IE8-9 -// ------------------------- - -:root .#{$el-css-prefix}-rotate-90, -:root .#{$el-css-prefix}-rotate-180, -:root .#{$el-css-prefix}-rotate-270, -:root .#{$el-css-prefix}-flip-horizontal, -:root .#{$el-css-prefix}-flip-vertical { - filter: none; -} diff --git a/library/admin/ReduxCore/assets/css/vendor/elusive-icons/scss/_stacked.scss b/library/admin/ReduxCore/assets/css/vendor/elusive-icons/scss/_stacked.scss deleted file mode 100644 index 68d84bb6..00000000 --- a/library/admin/ReduxCore/assets/css/vendor/elusive-icons/scss/_stacked.scss +++ /dev/null @@ -1,20 +0,0 @@ -// Stacked Icons -// ------------------------- - -.#{$el-css-prefix}-stack { - position: relative; - display: inline-block; - width: 2em; - height: 2em; - line-height: 2em; - vertical-align: middle; -} -.#{$el-css-prefix}-stack-1x, .#{$el-css-prefix}-stack-2x { - position: absolute; - left: 0; - width: 100%; - text-align: center; -} -.#{$el-css-prefix}-stack-1x { line-height: inherit; } -.#{$el-css-prefix}-stack-2x { font-size: 2em; } -.#{$el-css-prefix}-inverse { color: $el-inverse; } diff --git a/library/admin/ReduxCore/assets/css/vendor/elusive-icons/scss/_variables.scss b/library/admin/ReduxCore/assets/css/vendor/elusive-icons/scss/_variables.scss deleted file mode 100644 index b5ddf72a..00000000 --- a/library/admin/ReduxCore/assets/css/vendor/elusive-icons/scss/_variables.scss +++ /dev/null @@ -1,318 +0,0 @@ -// Variables -// -------------------------- - -$el-font-path: "fonts" !default; -$el-font-size-base: 14px !default; -$el-css-prefix: el !default; -$el-version: "2.0.0" !default; -$el-border-color: #eee !default; -$el-inverse: #fff !default; -$el-li-width: (30em / 14) !default; - -$el-var-address-book: "\f102"; -$el-var-address-book-alt: "\f101"; -$el-var-adjust: "\f104"; -$el-var-adjust-alt: "\f103"; -$el-var-adult: "\f105"; -$el-var-align-center: "\f106"; -$el-var-align-justify: "\f107"; -$el-var-align-left: "\f108"; -$el-var-align-right: "\f109"; -$el-var-arrow-down: "\f10a"; -$el-var-arrow-left: "\f10b"; -$el-var-arrow-right: "\f10c"; -$el-var-arrow-up: "\f10d"; -$el-var-asl: "\f10e"; -$el-var-asterisk: "\f10f"; -$el-var-backward: "\f110"; -$el-var-ban-circle: "\f111"; -$el-var-barcode: "\f112"; -$el-var-behance: "\f113"; -$el-var-bell: "\f114"; -$el-var-blind: "\f115"; -$el-var-blogger: "\f116"; -$el-var-bold: "\f117"; -$el-var-book: "\f118"; -$el-var-bookmark: "\f11a"; -$el-var-bookmark-empty: "\f119"; -$el-var-brackets: "\f11b"; -$el-var-braille: "\f11c"; -$el-var-briefcase: "\f11d"; -$el-var-broom: "\f11e"; -$el-var-brush: "\f11f"; -$el-var-bulb: "\f120"; -$el-var-bullhorn: "\f121"; -$el-var-calendar: "\f123"; -$el-var-calendar-sign: "\f122"; -$el-var-camera: "\f124"; -$el-var-car: "\f125"; -$el-var-caret-down: "\f126"; -$el-var-caret-left: "\f127"; -$el-var-caret-right: "\f128"; -$el-var-caret-up: "\f129"; -$el-var-cc: "\f12a"; -$el-var-certificate: "\f12b"; -$el-var-check: "\f12d"; -$el-var-check-empty: "\f12c"; -$el-var-chevron-down: "\f12e"; -$el-var-chevron-left: "\f12f"; -$el-var-chevron-right: "\f130"; -$el-var-chevron-up: "\f131"; -$el-var-child: "\f132"; -$el-var-circle-arrow-down: "\f133"; -$el-var-circle-arrow-left: "\f134"; -$el-var-circle-arrow-right: "\f135"; -$el-var-circle-arrow-up: "\f136"; -$el-var-cloud: "\f138"; -$el-var-cloud-alt: "\f137"; -$el-var-cog: "\f13a"; -$el-var-cog-alt: "\f139"; -$el-var-cogs: "\f13b"; -$el-var-comment: "\f13d"; -$el-var-comment-alt: "\f13c"; -$el-var-compass: "\f13f"; -$el-var-compass-alt: "\f13e"; -$el-var-credit-card: "\f140"; -$el-var-css: "\f141"; -$el-var-dashboard: "\f142"; -$el-var-delicious: "\f143"; -$el-var-deviantart: "\f144"; -$el-var-digg: "\f145"; -$el-var-download: "\f147"; -$el-var-download-alt: "\f146"; -$el-var-dribbble: "\f148"; -$el-var-edit: "\f149"; -$el-var-eject: "\f14a"; -$el-var-envelope: "\f14c"; -$el-var-envelope-alt: "\f14b"; -$el-var-error: "\f14e"; -$el-var-error-alt: "\f14d"; -$el-var-eur: "\f14f"; -$el-var-exclamation-sign: "\f150"; -$el-var-eye-close: "\f151"; -$el-var-eye-open: "\f152"; -$el-var-facebook: "\f153"; -$el-var-facetime-video: "\f154"; -$el-var-fast-backward: "\f155"; -$el-var-fast-forward: "\f156"; -$el-var-female: "\f157"; -$el-var-file: "\f15d"; -$el-var-file-alt: "\f158"; -$el-var-file-edit: "\f15a"; -$el-var-file-edit-alt: "\f159"; -$el-var-file-new: "\f15c"; -$el-var-file-new-alt: "\f15b"; -$el-var-film: "\f15e"; -$el-var-filter: "\f15f"; -$el-var-fire: "\f160"; -$el-var-flag: "\f162"; -$el-var-flag-alt: "\f161"; -$el-var-flickr: "\f163"; -$el-var-folder: "\f167"; -$el-var-folder-close: "\f164"; -$el-var-folder-open: "\f165"; -$el-var-folder-sign: "\f166"; -$el-var-font: "\f168"; -$el-var-fontsize: "\f169"; -$el-var-fork: "\f16a"; -$el-var-forward: "\f16c"; -$el-var-forward-alt: "\f16b"; -$el-var-foursquare: "\f16d"; -$el-var-friendfeed: "\f16f"; -$el-var-friendfeed-rect: "\f16e"; -$el-var-fullscreen: "\f170"; -$el-var-gallery: "\f171"; -$el-var-gbp: "\f172"; -$el-var-gift: "\f173"; -$el-var-github: "\f175"; -$el-var-github-text: "\f174"; -$el-var-glass: "\f176"; -$el-var-glasses: "\f177"; -$el-var-globe: "\f179"; -$el-var-globe-alt: "\f178"; -$el-var-googleplus: "\f17a"; -$el-var-graph: "\f17c"; -$el-var-graph-alt: "\f17b"; -$el-var-group: "\f17e"; -$el-var-group-alt: "\f17d"; -$el-var-guidedog: "\f17f"; -$el-var-hand-down: "\f180"; -$el-var-hand-left: "\f181"; -$el-var-hand-right: "\f182"; -$el-var-hand-up: "\f183"; -$el-var-hdd: "\f184"; -$el-var-headphones: "\f185"; -$el-var-hearing-impaired: "\f186"; -$el-var-heart: "\f189"; -$el-var-heart-alt: "\f187"; -$el-var-heart-empty: "\f188"; -$el-var-home: "\f18b"; -$el-var-home-alt: "\f18a"; -$el-var-hourglass: "\f18c"; -$el-var-idea: "\f18e"; -$el-var-idea-alt: "\f18d"; -$el-var-inbox: "\f191"; -$el-var-inbox-alt: "\f18f"; -$el-var-inbox-box: "\f190"; -$el-var-indent-left: "\f192"; -$el-var-indent-right: "\f193"; -$el-var-info-circle: "\f194"; -$el-var-instagram: "\f195"; -$el-var-iphone-home: "\f196"; -$el-var-italic: "\f197"; -$el-var-key: "\f198"; -$el-var-laptop: "\f19a"; -$el-var-laptop-alt: "\f199"; -$el-var-lastfm: "\f19b"; -$el-var-leaf: "\f19c"; -$el-var-lines: "\f19d"; -$el-var-link: "\f19e"; -$el-var-linkedin: "\f19f"; -$el-var-list: "\f1a1"; -$el-var-list-alt: "\f1a0"; -$el-var-livejournal: "\f1a2"; -$el-var-lock: "\f1a4"; -$el-var-lock-alt: "\f1a3"; -$el-var-magic: "\f1a5"; -$el-var-magnet: "\f1a6"; -$el-var-male: "\f1a7"; -$el-var-map-marker: "\f1a9"; -$el-var-map-marker-alt: "\f1a8"; -$el-var-mic: "\f1ab"; -$el-var-mic-alt: "\f1aa"; -$el-var-minus: "\f1ad"; -$el-var-minus-sign: "\f1ac"; -$el-var-move: "\f1ae"; -$el-var-music: "\f1af"; -$el-var-myspace: "\f1b0"; -$el-var-network: "\f1b1"; -$el-var-off: "\f1b2"; -$el-var-ok: "\f1b5"; -$el-var-ok-circle: "\f1b3"; -$el-var-ok-sign: "\f1b4"; -$el-var-opensource: "\f1b6"; -$el-var-paper-clip: "\f1b8"; -$el-var-paper-clip-alt: "\f1b7"; -$el-var-path: "\f1b9"; -$el-var-pause: "\f1bb"; -$el-var-pause-alt: "\f1ba"; -$el-var-pencil: "\f1bd"; -$el-var-pencil-alt: "\f1bc"; -$el-var-person: "\f1be"; -$el-var-phone: "\f1c0"; -$el-var-phone-alt: "\f1bf"; -$el-var-photo: "\f1c2"; -$el-var-photo-alt: "\f1c1"; -$el-var-picasa: "\f1c3"; -$el-var-picture: "\f1c4"; -$el-var-plane: "\f1c5"; -$el-var-play: "\f1c8"; -$el-var-play-alt: "\f1c6"; -$el-var-play-circle: "\f1c7"; -$el-var-plurk: "\f1ca"; -$el-var-plurk-alt: "\f1c9"; -$el-var-plus: "\f1cc"; -$el-var-plus-sign: "\f1cb"; -$el-var-podcast: "\f1cd"; -$el-var-print: "\f1ce"; -$el-var-puzzle: "\f1cf"; -$el-var-qrcode: "\f1d0"; -$el-var-question: "\f1d2"; -$el-var-question-sign: "\f1d1"; -$el-var-quote-alt: "\f1d3"; -$el-var-quote-right: "\f1d5"; -$el-var-quote-right-alt: "\f1d4"; -$el-var-quotes: "\f1d6"; -$el-var-random: "\f1d7"; -$el-var-record: "\f1d8"; -$el-var-reddit: "\f1d9"; -$el-var-redux: "\f1da"; -$el-var-refresh: "\f1db"; -$el-var-remove: "\f1de"; -$el-var-remove-circle: "\f1dc"; -$el-var-remove-sign: "\f1dd"; -$el-var-repeat: "\f1e0"; -$el-var-repeat-alt: "\f1df"; -$el-var-resize-full: "\f1e1"; -$el-var-resize-horizontal: "\f1e2"; -$el-var-resize-small: "\f1e3"; -$el-var-resize-vertical: "\f1e4"; -$el-var-return-key: "\f1e5"; -$el-var-retweet: "\f1e6"; -$el-var-reverse-alt: "\f1e7"; -$el-var-road: "\f1e8"; -$el-var-rss: "\f1e9"; -$el-var-scissors: "\f1ea"; -$el-var-screen: "\f1ec"; -$el-var-screen-alt: "\f1eb"; -$el-var-screenshot: "\f1ed"; -$el-var-search: "\f1ef"; -$el-var-search-alt: "\f1ee"; -$el-var-share: "\f1f1"; -$el-var-share-alt: "\f1f0"; -$el-var-shopping-cart: "\f1f3"; -$el-var-shopping-cart-sign: "\f1f2"; -$el-var-shortcode: "\f1f4"; -$el-var-signal: "\f1f5"; -$el-var-skype: "\f1f6"; -$el-var-slideshare: "\f1f7"; -$el-var-smiley: "\f1f9"; -$el-var-smiley-alt: "\f1f8"; -$el-var-soundcloud: "\f1fa"; -$el-var-speaker: "\f1fb"; -$el-var-spotify: "\f1fc"; -$el-var-stackoverflow: "\f1fd"; -$el-var-star: "\f200"; -$el-var-star-alt: "\f1fe"; -$el-var-star-empty: "\f1ff"; -$el-var-step-backward: "\f201"; -$el-var-step-forward: "\f202"; -$el-var-stop: "\f204"; -$el-var-stop-alt: "\f203"; -$el-var-stumbleupon: "\f205"; -$el-var-tag: "\f206"; -$el-var-tags: "\f207"; -$el-var-tasks: "\f208"; -$el-var-text-height: "\f209"; -$el-var-text-width: "\f20a"; -$el-var-th: "\f20d"; -$el-var-th-large: "\f20b"; -$el-var-th-list: "\f20c"; -$el-var-thumbs-down: "\f20e"; -$el-var-thumbs-up: "\f20f"; -$el-var-time: "\f211"; -$el-var-time-alt: "\f210"; -$el-var-tint: "\f212"; -$el-var-torso: "\f213"; -$el-var-trash: "\f215"; -$el-var-trash-alt: "\f214"; -$el-var-tumblr: "\f216"; -$el-var-twitter: "\f217"; -$el-var-universal-access: "\f218"; -$el-var-unlock: "\f21a"; -$el-var-unlock-alt: "\f219"; -$el-var-upload: "\f21b"; -$el-var-usd: "\f21c"; -$el-var-user: "\f21d"; -$el-var-viadeo: "\f21e"; -$el-var-video: "\f221"; -$el-var-video-alt: "\f21f"; -$el-var-video-chat: "\f220"; -$el-var-view-mode: "\f222"; -$el-var-vimeo: "\f223"; -$el-var-vkontakte: "\f224"; -$el-var-volume-down: "\f225"; -$el-var-volume-off: "\f226"; -$el-var-volume-up: "\f227"; -$el-var-w3c: "\f228"; -$el-var-warning-sign: "\f229"; -$el-var-website: "\f22b"; -$el-var-website-alt: "\f22a"; -$el-var-wheelchair: "\f22c"; -$el-var-wordpress: "\f22d"; -$el-var-wrench: "\f22f"; -$el-var-wrench-alt: "\f22e"; -$el-var-youtube: "\f230"; -$el-var-zoom-in: "\f231"; -$el-var-zoom-out: "\f232"; - diff --git a/library/admin/ReduxCore/assets/css/vendor/elusive-icons/scss/elusive-icons.css b/library/admin/ReduxCore/assets/css/vendor/elusive-icons/scss/elusive-icons.css deleted file mode 100644 index 7c203980..00000000 --- a/library/admin/ReduxCore/assets/css/vendor/elusive-icons/scss/elusive-icons.css +++ /dev/null @@ -1,4 +0,0 @@ -/*! - * Elusive Icons 2.0.0 by @ReduxFramework - http://elusiveicons.com - @reduxframework - * License - http://elusiveicons.com/license (Font: SIL OFL 1.1, CSS: MIT License) - */@font-face{font-family:'Elusive-Icons';src:url("fonts/elusiveicons-webfont.eot?v=2.0.0");src:url("fonts/elusiveicons-webfont.eot?#iefix&v=2.0.0") format("embedded-opentype"),url("fonts/elusiveicons-webfont.woff?v=2.0.0") format("woff"),url("fonts/elusiveicons-webfont.ttf?v=2.0.0") format("truetype"),url("fonts/elusiveicons-webfont.svg?v=2.0.0#elusiveiconsregular") format("svg");font-weight:normal;font-style:normal}.el{display:inline-block;font:normal normal normal 14px/1 "Elusive-Icons";font-size:inherit;text-rendering:auto;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transform:translate(0, 0)}.el-lg{font-size:1.33333em;line-height:0.75em;vertical-align:-15%}.el-2x{font-size:2em}.el-3x{font-size:3em}.el-4x{font-size:4em}.el-5x{font-size:5em}.el-fw{width:1.28571em;text-align:center}.el-ul{padding-left:0;margin-left:2.14286em;list-style-type:none}.el-ul>li{position:relative}.el-li{position:absolute;left:-2.14286em;width:2.14286em;top:0.14286em;text-align:center}.el-li.el-lg{left:-1.85714em}.el-border{padding:.2em .25em .15em;border:solid 0.08em #eee;border-radius:.1em}.pull-right{float:right}.pull-left{float:left}.el.pull-left{margin-right:.3em}.el.pull-right{margin-left:.3em}.el-spin{-webkit-animation:el-spin 2s infinite linear;animation:el-spin 2s infinite linear}.el-pulse{-webkit-animation:el-spin 1s infinite steps(8);animation:el-spin 1s infinite steps(8)}@-webkit-keyframes el-spin{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg)}100%{-webkit-transform:rotate(359deg);transform:rotate(359deg)}}@keyframes el-spin{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg)}100%{-webkit-transform:rotate(359deg);transform:rotate(359deg)}}.el-rotate-90{filter:progid:DXImageTransform.Microsoft.BasicImage(rotation=1);-webkit-transform:rotate(90deg);-ms-transform:rotate(90deg);transform:rotate(90deg)}.el-rotate-180{filter:progid:DXImageTransform.Microsoft.BasicImage(rotation=2);-webkit-transform:rotate(180deg);-ms-transform:rotate(180deg);transform:rotate(180deg)}.el-rotate-270{filter:progid:DXImageTransform.Microsoft.BasicImage(rotation=3);-webkit-transform:rotate(270deg);-ms-transform:rotate(270deg);transform:rotate(270deg)}.el-flip-horizontal{filter:progid:DXImageTransform.Microsoft.BasicImage(rotation=0);-webkit-transform:scale(-1, 1);-ms-transform:scale(-1, 1);transform:scale(-1, 1)}.el-flip-vertical{filter:progid:DXImageTransform.Microsoft.BasicImage(rotation=2);-webkit-transform:scale(1, -1);-ms-transform:scale(1, -1);transform:scale(1, -1)}:root .el-rotate-90,:root .el-rotate-180,:root .el-rotate-270,:root .el-flip-horizontal,:root .el-flip-vertical{filter:none}.el-stack{position:relative;display:inline-block;width:2em;height:2em;line-height:2em;vertical-align:middle}.el-stack-1x,.el-stack-2x{position:absolute;left:0;width:100%;text-align:center}.el-stack-1x{line-height:inherit}.el-stack-2x{font-size:2em}.el-inverse{color:#fff}.el-icon-address-book-alt:before,.el-address-book-alt:before{content:"ï„"}.el-icon-address-book:before,.el-address-book:before{content:"ï„‚"}.el-icon-adjust-alt:before,.el-adjust-alt:before{content:""}.el-icon-adjust:before,.el-adjust:before{content:"ï„„"}.el-icon-adult:before,.el-adult:before{content:"ï„…"}.el-icon-align-center:before,.el-align-center:before{content:""}.el-icon-align-justify:before,.el-align-justify:before{content:""}.el-icon-align-left:before,.el-align-left:before{content:""}.el-icon-align-right:before,.el-align-right:before{content:""}.el-icon-arrow-down:before,.el-arrow-down:before{content:"ï„Š"}.el-icon-arrow-left:before,.el-arrow-left:before{content:"ï„‹"}.el-icon-arrow-right:before,.el-arrow-right:before{content:"ï„Œ"}.el-icon-arrow-up:before,.el-arrow-up:before{content:"ï„"}.el-icon-asl:before,.el-asl:before{content:"ï„Ž"}.el-icon-asterisk:before,.el-asterisk:before{content:"ï„"}.el-icon-backward:before,.el-backward:before{content:"ï„"}.el-icon-ban-circle:before,.el-ban-circle:before{content:"ï„‘"}.el-icon-barcode:before,.el-barcode:before{content:"ï„’"}.el-icon-behance:before,.el-behance:before{content:"ï„“"}.el-icon-bell:before,.el-bell:before{content:"ï„”"}.el-icon-blind:before,.el-blind:before{content:"ï„•"}.el-icon-blogger:before,.el-blogger:before{content:"ï„–"}.el-icon-bold:before,.el-bold:before{content:"ï„—"}.el-icon-book:before,.el-book:before{content:""}.el-icon-bookmark-empty:before,.el-bookmark-empty:before{content:"ï„™"}.el-icon-bookmark:before,.el-bookmark:before{content:"ï„š"}.el-icon-brackets:before,.el-brackets:before{content:"ï„›"}.el-icon-braille:before,.el-braille:before{content:"ï„œ"}.el-icon-briefcase:before,.el-briefcase:before{content:"ï„"}.el-icon-broom:before,.el-broom:before{content:"ï„ž"}.el-icon-brush:before,.el-brush:before{content:"ï„Ÿ"}.el-icon-bulb:before,.el-bulb:before{content:"ï„ "}.el-icon-bullhorn:before,.el-bullhorn:before{content:"ï„¡"}.el-icon-calendar-sign:before,.el-calendar-sign:before{content:"ï„¢"}.el-icon-calendar:before,.el-calendar:before{content:"ï„£"}.el-icon-camera:before,.el-camera:before{content:""}.el-icon-car:before,.el-car:before{content:"ï„¥"}.el-icon-caret-down:before,.el-caret-down:before{content:""}.el-icon-caret-left:before,.el-caret-left:before{content:""}.el-icon-caret-right:before,.el-caret-right:before{content:""}.el-icon-caret-up:before,.el-caret-up:before{content:"ï„©"}.el-icon-cc:before,.el-cc:before{content:""}.el-icon-certificate:before,.el-certificate:before{content:"ï„«"}.el-icon-check-empty:before,.el-check-empty:before{content:""}.el-icon-check:before,.el-check:before{content:"ï„­"}.el-icon-chevron-down:before,.el-chevron-down:before{content:"ï„®"}.el-icon-chevron-left:before,.el-chevron-left:before{content:""}.el-icon-chevron-right:before,.el-chevron-right:before{content:"ï„°"}.el-icon-chevron-up:before,.el-chevron-up:before{content:""}.el-icon-child:before,.el-child:before{content:""}.el-icon-circle-arrow-down:before,.el-circle-arrow-down:before{content:""}.el-icon-circle-arrow-left:before,.el-circle-arrow-left:before{content:"ï„´"}.el-icon-circle-arrow-right:before,.el-circle-arrow-right:before{content:""}.el-icon-circle-arrow-up:before,.el-circle-arrow-up:before{content:""}.el-icon-cloud-alt:before,.el-cloud-alt:before{content:"ï„·"}.el-icon-cloud:before,.el-cloud:before{content:""}.el-icon-cog-alt:before,.el-cog-alt:before{content:""}.el-icon-cog:before,.el-cog:before{content:""}.el-icon-cogs:before,.el-cogs:before{content:"ï„»"}.el-icon-comment-alt:before,.el-comment-alt:before{content:""}.el-icon-comment:before,.el-comment:before{content:""}.el-icon-compass-alt:before,.el-compass-alt:before{content:""}.el-icon-compass:before,.el-compass:before{content:"ï„¿"}.el-icon-credit-card:before,.el-credit-card:before{content:"ï…€"}.el-icon-css:before,.el-css:before{content:"ï…"}.el-icon-dashboard:before,.el-dashboard:before{content:"ï…‚"}.el-icon-delicious:before,.el-delicious:before{content:"ï…ƒ"}.el-icon-deviantart:before,.el-deviantart:before{content:"ï…„"}.el-icon-digg:before,.el-digg:before{content:"ï……"}.el-icon-download-alt:before,.el-download-alt:before{content:"ï…†"}.el-icon-download:before,.el-download:before{content:"ï…‡"}.el-icon-dribbble:before,.el-dribbble:before{content:"ï…ˆ"}.el-icon-edit:before,.el-edit:before{content:"ï…‰"}.el-icon-eject:before,.el-eject:before{content:"ï…Š"}.el-icon-envelope-alt:before,.el-envelope-alt:before{content:"ï…‹"}.el-icon-envelope:before,.el-envelope:before{content:"ï…Œ"}.el-icon-error-alt:before,.el-error-alt:before{content:"ï…"}.el-icon-error:before,.el-error:before{content:"ï…Ž"}.el-icon-eur:before,.el-eur:before{content:"ï…"}.el-icon-exclamation-sign:before,.el-exclamation-sign:before{content:"ï…"}.el-icon-eye-close:before,.el-eye-close:before{content:"ï…‘"}.el-icon-eye-open:before,.el-eye-open:before{content:"ï…’"}.el-icon-facebook:before,.el-facebook:before{content:"ï…“"}.el-icon-facetime-video:before,.el-facetime-video:before{content:"ï…”"}.el-icon-fast-backward:before,.el-fast-backward:before{content:"ï…•"}.el-icon-fast-forward:before,.el-fast-forward:before{content:"ï…–"}.el-icon-female:before,.el-female:before{content:"ï…—"}.el-icon-file-alt:before,.el-file-alt:before{content:"ï…˜"}.el-icon-file-edit-alt:before,.el-file-edit-alt:before{content:"ï…™"}.el-icon-file-edit:before,.el-file-edit:before{content:"ï…š"}.el-icon-file-new-alt:before,.el-file-new-alt:before{content:"ï…›"}.el-icon-file-new:before,.el-file-new:before{content:"ï…œ"}.el-icon-file:before,.el-file:before{content:"ï…"}.el-icon-film:before,.el-film:before{content:"ï…ž"}.el-icon-filter:before,.el-filter:before{content:"ï…Ÿ"}.el-icon-fire:before,.el-fire:before{content:"ï… "}.el-icon-flag-alt:before,.el-flag-alt:before{content:"ï…¡"}.el-icon-flag:before,.el-flag:before{content:"ï…¢"}.el-icon-flickr:before,.el-flickr:before{content:"ï…£"}.el-icon-folder-close:before,.el-folder-close:before{content:"ï…¤"}.el-icon-folder-open:before,.el-folder-open:before{content:"ï…¥"}.el-icon-folder-sign:before,.el-folder-sign:before{content:"ï…¦"}.el-icon-folder:before,.el-folder:before{content:"ï…§"}.el-icon-font:before,.el-font:before{content:"ï…¨"}.el-icon-fontsize:before,.el-fontsize:before{content:"ï…©"}.el-icon-fork:before,.el-fork:before{content:"ï…ª"}.el-icon-forward-alt:before,.el-forward-alt:before{content:"ï…«"}.el-icon-forward:before,.el-forward:before{content:"ï…¬"}.el-icon-foursquare:before,.el-foursquare:before{content:"ï…­"}.el-icon-friendfeed-rect:before,.el-friendfeed-rect:before{content:"ï…®"}.el-icon-friendfeed:before,.el-friendfeed:before{content:"ï…¯"}.el-icon-fullscreen:before,.el-fullscreen:before{content:"ï…°"}.el-icon-gallery:before,.el-gallery:before{content:"ï…±"}.el-icon-gbp:before,.el-gbp:before{content:"ï…²"}.el-icon-gift:before,.el-gift:before{content:"ï…³"}.el-icon-github-text:before,.el-github-text:before{content:"ï…´"}.el-icon-github:before,.el-github:before{content:"ï…µ"}.el-icon-glass:before,.el-glass:before{content:"ï…¶"}.el-icon-glasses:before,.el-glasses:before{content:"ï…·"}.el-icon-globe-alt:before,.el-globe-alt:before{content:"ï…¸"}.el-icon-globe:before,.el-globe:before{content:"ï…¹"}.el-icon-googleplus:before,.el-googleplus:before{content:"ï…º"}.el-icon-graph-alt:before,.el-graph-alt:before{content:"ï…»"}.el-icon-graph:before,.el-graph:before{content:"ï…¼"}.el-icon-group-alt:before,.el-group-alt:before{content:"ï…½"}.el-icon-group:before,.el-group:before{content:"ï…¾"}.el-icon-guidedog:before,.el-guidedog:before{content:"ï…¿"}.el-icon-hand-down:before,.el-hand-down:before{content:""}.el-icon-hand-left:before,.el-hand-left:before{content:"ï†"}.el-icon-hand-right:before,.el-hand-right:before{content:""}.el-icon-hand-up:before,.el-hand-up:before{content:""}.el-icon-hdd:before,.el-hdd:before{content:""}.el-icon-headphones:before,.el-headphones:before{content:""}.el-icon-hearing-impaired:before,.el-hearing-impaired:before{content:""}.el-icon-heart-alt:before,.el-heart-alt:before{content:""}.el-icon-heart-empty:before,.el-heart-empty:before{content:""}.el-icon-heart:before,.el-heart:before{content:""}.el-icon-home-alt:before,.el-home-alt:before{content:""}.el-icon-home:before,.el-home:before{content:""}.el-icon-hourglass:before,.el-hourglass:before{content:""}.el-icon-idea-alt:before,.el-idea-alt:before{content:"ï†"}.el-icon-idea:before,.el-idea:before{content:""}.el-icon-inbox-alt:before,.el-inbox-alt:before{content:"ï†"}.el-icon-inbox-box:before,.el-inbox-box:before{content:"ï†"}.el-icon-inbox:before,.el-inbox:before{content:""}.el-icon-indent-left:before,.el-indent-left:before{content:""}.el-icon-indent-right:before,.el-indent-right:before{content:""}.el-icon-info-circle:before,.el-info-circle:before{content:""}.el-icon-instagram:before,.el-instagram:before{content:""}.el-icon-iphone-home:before,.el-iphone-home:before{content:""}.el-icon-italic:before,.el-italic:before{content:""}.el-icon-key:before,.el-key:before{content:""}.el-icon-laptop-alt:before,.el-laptop-alt:before{content:""}.el-icon-laptop:before,.el-laptop:before{content:""}.el-icon-lastfm:before,.el-lastfm:before{content:""}.el-icon-leaf:before,.el-leaf:before{content:""}.el-icon-lines:before,.el-lines:before{content:"ï†"}.el-icon-link:before,.el-link:before{content:""}.el-icon-linkedin:before,.el-linkedin:before{content:""}.el-icon-list-alt:before,.el-list-alt:before{content:""}.el-icon-list:before,.el-list:before{content:""}.el-icon-livejournal:before,.el-livejournal:before{content:""}.el-icon-lock-alt:before,.el-lock-alt:before{content:""}.el-icon-lock:before,.el-lock:before{content:""}.el-icon-magic:before,.el-magic:before{content:""}.el-icon-magnet:before,.el-magnet:before{content:""}.el-icon-male:before,.el-male:before{content:""}.el-icon-map-marker-alt:before,.el-map-marker-alt:before{content:""}.el-icon-map-marker:before,.el-map-marker:before{content:""}.el-icon-mic-alt:before,.el-mic-alt:before{content:""}.el-icon-mic:before,.el-mic:before{content:""}.el-icon-minus-sign:before,.el-minus-sign:before{content:""}.el-icon-minus:before,.el-minus:before{content:""}.el-icon-move:before,.el-move:before{content:""}.el-icon-music:before,.el-music:before{content:""}.el-icon-myspace:before,.el-myspace:before{content:""}.el-icon-network:before,.el-network:before{content:""}.el-icon-off:before,.el-off:before{content:""}.el-icon-ok-circle:before,.el-ok-circle:before{content:""}.el-icon-ok-sign:before,.el-ok-sign:before{content:""}.el-icon-ok:before,.el-ok:before{content:""}.el-icon-opensource:before,.el-opensource:before{content:""}.el-icon-paper-clip-alt:before,.el-paper-clip-alt:before{content:""}.el-icon-paper-clip:before,.el-paper-clip:before{content:""}.el-icon-path:before,.el-path:before{content:""}.el-icon-pause-alt:before,.el-pause-alt:before{content:""}.el-icon-pause:before,.el-pause:before{content:""}.el-icon-pencil-alt:before,.el-pencil-alt:before{content:""}.el-icon-pencil:before,.el-pencil:before{content:""}.el-icon-person:before,.el-person:before{content:""}.el-icon-phone-alt:before,.el-phone-alt:before{content:""}.el-icon-phone:before,.el-phone:before{content:""}.el-icon-photo-alt:before,.el-photo-alt:before{content:"ï‡"}.el-icon-photo:before,.el-photo:before{content:""}.el-icon-picasa:before,.el-picasa:before{content:""}.el-icon-picture:before,.el-picture:before{content:""}.el-icon-plane:before,.el-plane:before{content:""}.el-icon-play-alt:before,.el-play-alt:before{content:""}.el-icon-play-circle:before,.el-play-circle:before{content:""}.el-icon-play:before,.el-play:before{content:""}.el-icon-plurk-alt:before,.el-plurk-alt:before{content:""}.el-icon-plurk:before,.el-plurk:before{content:""}.el-icon-plus-sign:before,.el-plus-sign:before{content:""}.el-icon-plus:before,.el-plus:before{content:""}.el-icon-podcast:before,.el-podcast:before{content:"ï‡"}.el-icon-print:before,.el-print:before{content:""}.el-icon-puzzle:before,.el-puzzle:before{content:"ï‡"}.el-icon-qrcode:before,.el-qrcode:before{content:"ï‡"}.el-icon-question-sign:before,.el-question-sign:before{content:""}.el-icon-question:before,.el-question:before{content:""}.el-icon-quote-alt:before,.el-quote-alt:before{content:""}.el-icon-quote-right-alt:before,.el-quote-right-alt:before{content:""}.el-icon-quote-right:before,.el-quote-right:before{content:""}.el-icon-quotes:before,.el-quotes:before{content:""}.el-icon-random:before,.el-random:before{content:""}.el-icon-record:before,.el-record:before{content:""}.el-icon-reddit:before,.el-reddit:before{content:""}.el-icon-redux:before,.el-redux:before{content:""}.el-icon-refresh:before,.el-refresh:before{content:""}.el-icon-remove-circle:before,.el-remove-circle:before{content:""}.el-icon-remove-sign:before,.el-remove-sign:before{content:"ï‡"}.el-icon-remove:before,.el-remove:before{content:""}.el-icon-repeat-alt:before,.el-repeat-alt:before{content:""}.el-icon-repeat:before,.el-repeat:before{content:""}.el-icon-resize-full:before,.el-resize-full:before{content:""}.el-icon-resize-horizontal:before,.el-resize-horizontal:before{content:""}.el-icon-resize-small:before,.el-resize-small:before{content:""}.el-icon-resize-vertical:before,.el-resize-vertical:before{content:""}.el-icon-return-key:before,.el-return-key:before{content:""}.el-icon-retweet:before,.el-retweet:before{content:""}.el-icon-reverse-alt:before,.el-reverse-alt:before{content:""}.el-icon-road:before,.el-road:before{content:""}.el-icon-rss:before,.el-rss:before{content:""}.el-icon-scissors:before,.el-scissors:before{content:""}.el-icon-screen-alt:before,.el-screen-alt:before{content:""}.el-icon-screen:before,.el-screen:before{content:""}.el-icon-screenshot:before,.el-screenshot:before{content:""}.el-icon-search-alt:before,.el-search-alt:before{content:""}.el-icon-search:before,.el-search:before{content:""}.el-icon-share-alt:before,.el-share-alt:before{content:""}.el-icon-share:before,.el-share:before{content:""}.el-icon-shopping-cart-sign:before,.el-shopping-cart-sign:before{content:""}.el-icon-shopping-cart:before,.el-shopping-cart:before{content:""}.el-icon-shortcode:before,.el-shortcode:before{content:""}.el-icon-signal:before,.el-signal:before{content:""}.el-icon-skype:before,.el-skype:before{content:""}.el-icon-slideshare:before,.el-slideshare:before{content:""}.el-icon-smiley-alt:before,.el-smiley-alt:before{content:""}.el-icon-smiley:before,.el-smiley:before{content:""}.el-icon-soundcloud:before,.el-soundcloud:before{content:""}.el-icon-speaker:before,.el-speaker:before{content:""}.el-icon-spotify:before,.el-spotify:before{content:""}.el-icon-stackoverflow:before,.el-stackoverflow:before{content:""}.el-icon-star-alt:before,.el-star-alt:before{content:""}.el-icon-star-empty:before,.el-star-empty:before{content:""}.el-icon-star:before,.el-star:before{content:""}.el-icon-step-backward:before,.el-step-backward:before{content:"ïˆ"}.el-icon-step-forward:before,.el-step-forward:before{content:""}.el-icon-stop-alt:before,.el-stop-alt:before{content:""}.el-icon-stop:before,.el-stop:before{content:""}.el-icon-stumbleupon:before,.el-stumbleupon:before{content:""}.el-icon-tag:before,.el-tag:before{content:""}.el-icon-tags:before,.el-tags:before{content:""}.el-icon-tasks:before,.el-tasks:before{content:""}.el-icon-text-height:before,.el-text-height:before{content:""}.el-icon-text-width:before,.el-text-width:before{content:""}.el-icon-th-large:before,.el-th-large:before{content:""}.el-icon-th-list:before,.el-th-list:before{content:""}.el-icon-th:before,.el-th:before{content:"ïˆ"}.el-icon-thumbs-down:before,.el-thumbs-down:before{content:""}.el-icon-thumbs-up:before,.el-thumbs-up:before{content:"ïˆ"}.el-icon-time-alt:before,.el-time-alt:before{content:"ïˆ"}.el-icon-time:before,.el-time:before{content:""}.el-icon-tint:before,.el-tint:before{content:""}.el-icon-torso:before,.el-torso:before{content:""}.el-icon-trash-alt:before,.el-trash-alt:before{content:""}.el-icon-trash:before,.el-trash:before{content:""}.el-icon-tumblr:before,.el-tumblr:before{content:""}.el-icon-twitter:before,.el-twitter:before{content:""}.el-icon-universal-access:before,.el-universal-access:before{content:""}.el-icon-unlock-alt:before,.el-unlock-alt:before{content:""}.el-icon-unlock:before,.el-unlock:before{content:""}.el-icon-upload:before,.el-upload:before{content:""}.el-icon-usd:before,.el-usd:before{content:""}.el-icon-user:before,.el-user:before{content:"ïˆ"}.el-icon-viadeo:before,.el-viadeo:before{content:""}.el-icon-video-alt:before,.el-video-alt:before{content:""}.el-icon-video-chat:before,.el-video-chat:before{content:""}.el-icon-video:before,.el-video:before{content:""}.el-icon-view-mode:before,.el-view-mode:before{content:""}.el-icon-vimeo:before,.el-vimeo:before{content:""}.el-icon-vkontakte:before,.el-vkontakte:before{content:""}.el-icon-volume-down:before,.el-volume-down:before{content:""}.el-icon-volume-off:before,.el-volume-off:before{content:""}.el-icon-volume-up:before,.el-volume-up:before{content:""}.el-icon-w3c:before,.el-w3c:before{content:""}.el-icon-warning-sign:before,.el-warning-sign:before{content:""}.el-icon-website-alt:before,.el-website-alt:before{content:""}.el-icon-website:before,.el-website:before{content:""}.el-icon-wheelchair:before,.el-wheelchair:before{content:""}.el-icon-wordpress:before,.el-wordpress:before{content:""}.el-icon-wrench-alt:before,.el-wrench-alt:before{content:""}.el-icon-wrench:before,.el-wrench:before{content:""}.el-icon-youtube:before,.el-youtube:before{content:""}.el-icon-zoom-in:before,.el-zoom-in:before{content:""}.el-icon-zoom-out:before,.el-zoom-out:before{content:""} diff --git a/library/admin/ReduxCore/assets/css/vendor/elusive-icons/scss/elusive-icons.css.map b/library/admin/ReduxCore/assets/css/vendor/elusive-icons/scss/elusive-icons.css.map deleted file mode 100644 index c576afb4..00000000 --- a/library/admin/ReduxCore/assets/css/vendor/elusive-icons/scss/elusive-icons.css.map +++ /dev/null @@ -1,7 +0,0 @@ -{ -"version": 3, -"mappings": ";;;;;;;AAGA,UAUC;EATC,WAAW,EAAE,eAAe;EAC5B,GAAG,EAAE,6CAAiE;EACtE,GAAG,EAAE,kSAAoG;EAKzG,WAAW,EAAE,MAAM;EACnB,UAAU,EAAE,MAAM;ACTpB,GAAmB;EACjB,OAAO,EAAE,YAAY;EACrB,IAAI,EAAE,2CAA4D;EAClE,SAAS,EAAE,OAAO;EAClB,cAAc,EAAE,IAAI;EACpB,sBAAsB,EAAE,WAAW;EACnC,uBAAuB,EAAE,SAAS;EAClC,SAAS,EAAE,eAAe;;;ACN5B,MAAsB;EACpB,SAAS,EAAE,SAAS;EACpB,WAAW,EAAE,MAAS;EACtB,cAAc,EAAE,IAAI;;AAEtB,MAAsB;EAAE,SAAS,EAAE,GAAG;;AACtC,MAAsB;EAAE,SAAS,EAAE,GAAG;;AACtC,MAAsB;EAAE,SAAS,EAAE,GAAG;;AACtC,MAAsB;EAAE,SAAS,EAAE,GAAG;;ACVtC,MAAsB;EACpB,KAAK,EAAE,SAAW;EAClB,UAAU,EAAE,MAAM;;ACDpB,MAAsB;EACpB,YAAY,EAAE,CAAC;EACf,WAAW,ECIU,SAAS;EDH9B,eAAe,EAAE,IAAI;EACrB,WAAK;IAAE,QAAQ,EAAE,QAAQ;;AAE3B,MAAsB;EACpB,QAAQ,EAAE,QAAQ;EAClB,IAAI,EAAE,UAAa;EACnB,KAAK,ECHgB,SAAS;EDI9B,GAAG,EAAE,SAAU;EACf,UAAU,EAAE,MAAM;EAClB,YAAuB;IACrB,IAAI,EAAE,UAA0B;;AEbpC,UAA0B;EACxB,OAAO,EAAE,gBAAgB;EACzB,MAAM,EAAE,iBAA4B;EACpC,aAAa,EAAE,IAAI;;AAGrB,WAAY;EAAE,KAAK,EAAE,KAAK;;AAC1B,UAAW;EAAE,KAAK,EAAE,IAAI;;AAGtB,aAAY;EAAE,YAAY,EAAE,IAAI;AAChC,cAAa;EAAE,WAAW,EAAE,IAAI;;ACXlC,QAAwB;EACtB,iBAAiB,EAAE,0BAA0B;EACrC,SAAS,EAAE,0BAA0B;;AAG/C,SAAyB;EACvB,iBAAiB,EAAE,4BAA4B;EACvC,SAAS,EAAE,4BAA4B;;AAGjD,0BASC;EARC,EAAG;IACD,iBAAiB,EAAE,YAAY;IACvB,SAAS,EAAE,YAAY;EAEjC,IAAK;IACH,iBAAiB,EAAE,cAAc;IACzB,SAAS,EAAE,cAAc;AAIrC,kBASC;EARC,EAAG;IACD,iBAAiB,EAAE,YAAY;IACvB,SAAS,EAAE,YAAY;EAEjC,IAAK;IACH,iBAAiB,EAAE,cAAc;IACzB,SAAS,EAAE,cAAc;AC5BrC,aAA8B;ECY5B,MAAM,EAAE,wDAAmE;EAC3E,iBAAiB,EAAE,aAAgB;EAC/B,aAAa,EAAE,aAAgB;EAC3B,SAAS,EAAE,aAAgB;;ADdrC,cAA8B;ECW5B,MAAM,EAAE,wDAAmE;EAC3E,iBAAiB,EAAE,cAAgB;EAC/B,aAAa,EAAE,cAAgB;EAC3B,SAAS,EAAE,cAAgB;;ADbrC,cAA8B;ECU5B,MAAM,EAAE,wDAAmE;EAC3E,iBAAiB,EAAE,cAAgB;EAC/B,aAAa,EAAE,cAAgB;EAC3B,SAAS,EAAE,cAAgB;;ADXrC,mBAAmC;ECejC,MAAM,EAAE,wDAAmE;EAC3E,iBAAiB,EAAE,YAAoB;EACnC,aAAa,EAAE,YAAoB;EAC/B,SAAS,EAAE,YAAoB;;ADjBzC,iBAAmC;ECcjC,MAAM,EAAE,wDAAmE;EAC3E,iBAAiB,EAAE,YAAoB;EACnC,aAAa,EAAE,YAAoB;EAC/B,SAAS,EAAE,YAAoB;;ADZzC;;;;uBAIuC;EACrC,MAAM,EAAE,IAAI;;AEfd,SAAyB;EACvB,QAAQ,EAAE,QAAQ;EAClB,OAAO,EAAE,YAAY;EACrB,KAAK,EAAE,GAAG;EACV,MAAM,EAAE,GAAG;EACX,WAAW,EAAE,GAAG;EAChB,cAAc,EAAE,MAAM;;AAExB,0BAAyD;EACvD,QAAQ,EAAE,QAAQ;EAClB,IAAI,EAAE,CAAC;EACP,KAAK,EAAE,IAAI;EACX,UAAU,EAAE,MAAM;;AAEpB,YAA4B;EAAE,WAAW,EAAE,OAAO;;AAClD,YAA4B;EAAE,SAAS,EAAE,GAAG;;AAC5C,WAA2B;EAAE,KAAK,ELXZ,IAAI;;;;AML1B;2BAC2C;EAAE,OAAO,ENQ1B,GAAO;;AMPjC;uBACuC;EAAE,OAAO,ENK1B,GAAO;;AMJ7B;qBACqC;EAAE,OAAO,ENM1B,GAAO;;AML3B;iBACiC;EAAE,OAAO,ENG1B,GAAO;;AMFvB;gBACgC;EAAE,OAAO,ENG1B,GAAO;;AMFtB;uBACuC;EAAE,OAAO,ENE1B,GAAO;;AMD7B;wBACwC;EAAE,OAAO,ENC1B,GAAO;;AMA9B;qBACqC;EAAE,OAAO,ENA1B,GAAO;;AMC3B;sBACsC;EAAE,OAAO,END1B,GAAO;;AME5B;qBACqC;EAAE,OAAO,ENF1B,GAAO;;AMG3B;qBACqC;EAAE,OAAO,ENH1B,GAAO;;AMI3B;sBACsC;EAAE,OAAO,ENJ1B,GAAO;;AMK5B;mBACmC;EAAE,OAAO,ENL1B,GAAO;;AMMzB;cAC8B;EAAE,OAAO,ENN1B,GAAO;;AMOpB;mBACmC;EAAE,OAAO,ENP1B,GAAO;;AMQzB;mBACmC;EAAE,OAAO,ENR1B,GAAO;;AMSzB;qBACqC;EAAE,OAAO,ENT1B,GAAO;;AMU3B;kBACkC;EAAE,OAAO,ENV1B,GAAO;;AMWxB;kBACkC;EAAE,OAAO,ENX1B,GAAO;;AMYxB;eAC+B;EAAE,OAAO,ENZ1B,GAAO;;AMarB;gBACgC;EAAE,OAAO,ENb1B,GAAO;;AMctB;kBACkC;EAAE,OAAO,ENd1B,GAAO;;AMexB;eAC+B;EAAE,OAAO,ENf1B,GAAO;;AMgBrB;eAC+B;EAAE,OAAO,ENhB1B,GAAO;;AMiBrB;yBACyC;EAAE,OAAO,ENhB1B,GAAO;;AMiB/B;mBACmC;EAAE,OAAO,ENnB1B,GAAO;;AMoBzB;mBACmC;EAAE,OAAO,ENnB1B,GAAO;;AMoBzB;kBACkC;EAAE,OAAO,ENpB1B,GAAO;;AMqBxB;oBACoC;EAAE,OAAO,ENrB1B,GAAO;;AMsB1B;gBACgC;EAAE,OAAO,ENtB1B,GAAO;;AMuBtB;gBACgC;EAAE,OAAO,ENvB1B,GAAO;;AMwBtB;eAC+B;EAAE,OAAO,ENxB1B,GAAO;;AMyBrB;mBACmC;EAAE,OAAO,ENzB1B,GAAO;;AM0BzB;wBACwC;EAAE,OAAO,ENzB1B,GAAO;;AM0B9B;mBACmC;EAAE,OAAO,EN5B1B,GAAO;;AM6BzB;iBACiC;EAAE,OAAO,EN5B1B,GAAO;;AM6BvB;cAC8B;EAAE,OAAO,EN7B1B,GAAO;;AM8BpB;qBACqC;EAAE,OAAO,EN9B1B,GAAO;;AM+B3B;qBACqC;EAAE,OAAO,EN/B1B,GAAO;;AMgC3B;sBACsC;EAAE,OAAO,ENhC1B,GAAO;;AMiC5B;mBACmC;EAAE,OAAO,ENjC1B,GAAO;;AMkCzB;aAC6B;EAAE,OAAO,ENlC1B,GAAO;;AMmCnB;sBACsC;EAAE,OAAO,ENnC1B,GAAO;;AMoC5B;sBACsC;EAAE,OAAO,ENnC1B,GAAO;;AMoC5B;gBACgC;EAAE,OAAO,ENtC1B,GAAO;;AMuCtB;uBACuC;EAAE,OAAO,ENtC1B,GAAO;;AMuC7B;uBACuC;EAAE,OAAO,ENvC1B,GAAO;;AMwC7B;wBACwC;EAAE,OAAO,ENxC1B,GAAO;;AMyC9B;qBACqC;EAAE,OAAO,ENzC1B,GAAO;;AM0C3B;gBACgC;EAAE,OAAO,EN1C1B,GAAO;;AM2CtB;4BAC4C;EAAE,OAAO,EN3C1B,GAAO;;AM4ClC;4BAC4C;EAAE,OAAO,EN5C1B,GAAO;;AM6ClC;6BAC6C;EAAE,OAAO,EN7C1B,GAAO;;AM8CnC;0BAC0C;EAAE,OAAO,EN9C1B,GAAO;;AM+ChC;oBACoC;EAAE,OAAO,EN9C1B,GAAO;;AM+C1B;gBACgC;EAAE,OAAO,ENjD1B,GAAO;;AMkDtB;kBACkC;EAAE,OAAO,ENhD1B,GAAO;;AMiDxB;cAC8B;EAAE,OAAO,ENnD1B,GAAO;;AMoDpB;eAC+B;EAAE,OAAO,ENnD1B,GAAO;;AMoDrB;sBACsC;EAAE,OAAO,ENnD1B,GAAO;;AMoD5B;kBACkC;EAAE,OAAO,ENtD1B,GAAO;;AMuDxB;sBACsC;EAAE,OAAO,ENrD1B,GAAO;;AMsD5B;kBACkC;EAAE,OAAO,ENxD1B,GAAO;;AMyDxB;sBACsC;EAAE,OAAO,ENxD1B,GAAO;;AMyD5B;cAC8B;EAAE,OAAO,ENzD1B,GAAO;;AM0DpB;oBACoC;EAAE,OAAO,EN1D1B,GAAO;;AM2D1B;oBACoC;EAAE,OAAO,EN3D1B,GAAO;;AM4D1B;qBACqC;EAAE,OAAO,EN5D1B,GAAO;;AM6D3B;eAC+B;EAAE,OAAO,EN7D1B,GAAO;;AM8DrB;uBACuC;EAAE,OAAO,EN7D1B,GAAO;;AM8D7B;mBACmC;EAAE,OAAO,ENhE1B,GAAO;;AMiEzB;mBACmC;EAAE,OAAO,ENhE1B,GAAO;;AMiEzB;eAC+B;EAAE,OAAO,ENjE1B,GAAO;;AMkErB;gBACgC;EAAE,OAAO,ENlE1B,GAAO;;AMmEtB;uBACuC;EAAE,OAAO,ENlE1B,GAAO;;AMmE7B;mBACmC;EAAE,OAAO,ENrE1B,GAAO;;AMsEzB;oBACoC;EAAE,OAAO,ENpE1B,GAAO;;AMqE1B;gBACgC;EAAE,OAAO,ENvE1B,GAAO;;AMwEtB;cAC8B;EAAE,OAAO,ENvE1B,GAAO;;AMwEpB;2BAC2C;EAAE,OAAO,ENxE1B,GAAO;;AMyEjC;oBACoC;EAAE,OAAO,ENzE1B,GAAO;;AM0E1B;mBACmC;EAAE,OAAO,EN1E1B,GAAO;;AM2EzB;mBACmC;EAAE,OAAO,EN3E1B,GAAO;;AM4EzB;yBACyC;EAAE,OAAO,EN5E1B,GAAO;;AM6E/B;wBACwC;EAAE,OAAO,EN7E1B,GAAO;;AM8E9B;uBACuC;EAAE,OAAO,EN9E1B,GAAO;;AM+E7B;iBACiC;EAAE,OAAO,EN/E1B,GAAO;;AMgFvB;mBACmC;EAAE,OAAO,EN/E1B,GAAO;;AMgFzB;wBACwC;EAAE,OAAO,EN/E1B,GAAO;;AMgF9B;oBACoC;EAAE,OAAO,ENlF1B,GAAO;;AMmF1B;uBACuC;EAAE,OAAO,ENjF1B,GAAO;;AMkF7B;mBACmC;EAAE,OAAO,ENpF1B,GAAO;;AMqFzB;eAC+B;EAAE,OAAO,EN1F1B,GAAO;;AM2FrB;eAC+B;EAAE,OAAO,ENtF1B,GAAO;;AMuFrB;iBACiC;EAAE,OAAO,ENvF1B,GAAO;;AMwFvB;eAC+B;EAAE,OAAO,ENxF1B,GAAO;;AMyFrB;mBACmC;EAAE,OAAO,ENxF1B,GAAO;;AMyFzB;eAC+B;EAAE,OAAO,EN3F1B,GAAO;;AM4FrB;iBACiC;EAAE,OAAO,EN3F1B,GAAO;;AM4FvB;uBACuC;EAAE,OAAO,EN3F1B,GAAO;;AM4F7B;sBACsC;EAAE,OAAO,EN5F1B,GAAO;;AM6F5B;sBACsC;EAAE,OAAO,EN7F1B,GAAO;;AM8F5B;iBACiC;EAAE,OAAO,ENlG1B,GAAO;;AMmGvB;eAC+B;EAAE,OAAO,ENhG1B,GAAO;;AMiGrB;mBACmC;EAAE,OAAO,ENjG1B,GAAO;;AMkGzB;eAC+B;EAAE,OAAO,ENlG1B,GAAO;;AMmGrB;sBACsC;EAAE,OAAO,ENlG1B,GAAO;;AMmG5B;kBACkC;EAAE,OAAO,ENrG1B,GAAO;;AMsGxB;qBACqC;EAAE,OAAO,ENrG1B,GAAO;;AMsG3B;0BAC0C;EAAE,OAAO,ENrG1B,GAAO;;AMsGhC;qBACqC;EAAE,OAAO,ENxG1B,GAAO;;AMyG3B;qBACqC;EAAE,OAAO,ENxG1B,GAAO;;AMyG3B;kBACkC;EAAE,OAAO,ENzG1B,GAAO;;AM0GxB;cAC8B;EAAE,OAAO,EN1G1B,GAAO;;AM2GpB;eAC+B;EAAE,OAAO,EN3G1B,GAAO;;AM4GrB;sBACsC;EAAE,OAAO,EN3G1B,GAAO;;AM4G5B;iBACiC;EAAE,OAAO,EN9G1B,GAAO;;AM+GvB;gBACgC;EAAE,OAAO,EN9G1B,GAAO;;AM+GtB;kBACkC;EAAE,OAAO,EN/G1B,GAAO;;AMgHxB;oBACoC;EAAE,OAAO,EN/G1B,GAAO;;AMgH1B;gBACgC;EAAE,OAAO,ENlH1B,GAAO;;AMmHtB;qBACqC;EAAE,OAAO,ENlH1B,GAAO;;AMmH3B;oBACoC;EAAE,OAAO,ENlH1B,GAAO;;AMmH1B;gBACgC;EAAE,OAAO,ENrH1B,GAAO;;AMsHtB;oBACoC;EAAE,OAAO,ENpH1B,GAAO;;AMqH1B;gBACgC;EAAE,OAAO,ENvH1B,GAAO;;AMwHtB;mBACmC;EAAE,OAAO,ENvH1B,GAAO;;AMwHzB;oBACoC;EAAE,OAAO,ENxH1B,GAAO;;AMyH1B;oBACoC;EAAE,OAAO,ENzH1B,GAAO;;AM0H1B;qBACqC;EAAE,OAAO,EN1H1B,GAAO;;AM2H3B;kBACkC;EAAE,OAAO,EN3H1B,GAAO;;AM4HxB;cAC8B;EAAE,OAAO,EN5H1B,GAAO;;AM6HpB;qBACqC;EAAE,OAAO,EN7H1B,GAAO;;AM8H3B;2BAC2C;EAAE,OAAO,EN9H1B,GAAO;;AM+HjC;oBACoC;EAAE,OAAO,EN9H1B,GAAO;;AM+H1B;sBACsC;EAAE,OAAO,EN/H1B,GAAO;;AMgI5B;gBACgC;EAAE,OAAO,ENnI1B,GAAO;;AMoItB;mBACmC;EAAE,OAAO,ENjI1B,GAAO;;AMkIzB;eAC+B;EAAE,OAAO,ENpI1B,GAAO;;AMqIrB;oBACoC;EAAE,OAAO,ENpI1B,GAAO;;AMqI1B;mBACmC;EAAE,OAAO,ENpI1B,GAAO;;AMqIzB;eAC+B;EAAE,OAAO,ENvI1B,GAAO;;AMwIrB;oBACoC;EAAE,OAAO,ENtI1B,GAAO;;AMuI1B;oBACoC;EAAE,OAAO,ENvI1B,GAAO;;AMwI1B;gBACgC;EAAE,OAAO,EN3I1B,GAAO;;AM4ItB;sBACsC;EAAE,OAAO,EN1I1B,GAAO;;AM2I5B;uBACuC;EAAE,OAAO,EN3I1B,GAAO;;AM4I7B;sBACsC;EAAE,OAAO,EN5I1B,GAAO;;AM6I5B;oBACoC;EAAE,OAAO,EN7I1B,GAAO;;AM8I1B;sBACsC;EAAE,OAAO,EN9I1B,GAAO;;AM+I5B;iBACiC;EAAE,OAAO,EN/I1B,GAAO;;AMgJvB;cAC8B;EAAE,OAAO,ENhJ1B,GAAO;;AMiJpB;qBACqC;EAAE,OAAO,ENhJ1B,GAAO;;AMiJ3B;iBACiC;EAAE,OAAO,ENnJ1B,GAAO;;AMoJvB;iBACiC;EAAE,OAAO,ENnJ1B,GAAO;;AMoJvB;eAC+B;EAAE,OAAO,ENpJ1B,GAAO;;AMqJrB;gBACgC;EAAE,OAAO,ENrJ1B,GAAO;;AMsJtB;eAC+B;EAAE,OAAO,ENtJ1B,GAAO;;AMuJrB;mBACmC;EAAE,OAAO,ENvJ1B,GAAO;;AMwJzB;mBACmC;EAAE,OAAO,ENvJ1B,GAAO;;AMwJzB;eAC+B;EAAE,OAAO,EN1J1B,GAAO;;AM2JrB;sBACsC;EAAE,OAAO,EN1J1B,GAAO;;AM2J5B;mBACmC;EAAE,OAAO,EN1J1B,GAAO;;AM2JzB;eAC+B;EAAE,OAAO,EN7J1B,GAAO;;AM8JrB;gBACgC;EAAE,OAAO,EN7J1B,GAAO;;AM8JtB;iBACiC;EAAE,OAAO,EN9J1B,GAAO;;AM+JvB;eAC+B;EAAE,OAAO,EN/J1B,GAAO;;AMgKrB;yBACyC;EAAE,OAAO,EN/J1B,GAAO;;AMgK/B;qBACqC;EAAE,OAAO,ENlK1B,GAAO;;AMmK3B;kBACkC;EAAE,OAAO,ENjK1B,GAAO;;AMkKxB;cAC8B;EAAE,OAAO,ENpK1B,GAAO;;AMqKpB;qBACqC;EAAE,OAAO,ENnK1B,GAAO;;AMoK3B;gBACgC;EAAE,OAAO,ENtK1B,GAAO;;AMuKtB;eAC+B;EAAE,OAAO,ENtK1B,GAAO;;AMuKrB;gBACgC;EAAE,OAAO,ENvK1B,GAAO;;AMwKtB;kBACkC;EAAE,OAAO,ENxK1B,GAAO;;AMyKxB;kBACkC;EAAE,OAAO,ENzK1B,GAAO;;AM0KxB;cAC8B;EAAE,OAAO,EN1K1B,GAAO;;AM2KpB;oBACoC;EAAE,OAAO,EN1K1B,GAAO;;AM2K1B;kBACkC;EAAE,OAAO,EN3K1B,GAAO;;AM4KxB;aAC6B;EAAE,OAAO,EN/K1B,GAAO;;AMgLnB;qBACqC;EAAE,OAAO,EN9K1B,GAAO;;AM+K3B;yBACyC;EAAE,OAAO,EN9K1B,GAAO;;AM+K/B;qBACqC;EAAE,OAAO,ENjL1B,GAAO;;AMkL3B;eAC+B;EAAE,OAAO,ENjL1B,GAAO;;AMkLrB;oBACoC;EAAE,OAAO,ENjL1B,GAAO;;AMkL1B;gBACgC;EAAE,OAAO,ENpL1B,GAAO;;AMqLtB;qBACqC;EAAE,OAAO,ENnL1B,GAAO;;AMoL3B;iBACiC;EAAE,OAAO,ENtL1B,GAAO;;AMuLvB;iBACiC;EAAE,OAAO,ENtL1B,GAAO;;AMuLvB;oBACoC;EAAE,OAAO,ENtL1B,GAAO;;AMuL1B;gBACgC;EAAE,OAAO,ENzL1B,GAAO;;AM0LtB;oBACoC;EAAE,OAAO,ENxL1B,GAAO;;AMyL1B;gBACgC;EAAE,OAAO,EN3L1B,GAAO;;AM4LtB;iBACiC;EAAE,OAAO,EN3L1B,GAAO;;AM4LvB;kBACkC;EAAE,OAAO,EN5L1B,GAAO;;AM6LxB;gBACgC;EAAE,OAAO,EN7L1B,GAAO;;AM8LtB;mBACmC;EAAE,OAAO,EN7L1B,GAAO;;AM8LzB;sBACsC;EAAE,OAAO,EN9L1B,GAAO;;AM+L5B;eAC+B;EAAE,OAAO,ENlM1B,GAAO;;AMmMrB;oBACoC;EAAE,OAAO,ENhM1B,GAAO;;AMiM1B;gBACgC;EAAE,OAAO,ENnM1B,GAAO;;AMoMtB;oBACoC;EAAE,OAAO,ENlM1B,GAAO;;AMmM1B;eAC+B;EAAE,OAAO,ENrM1B,GAAO;;AMsMrB;kBACkC;EAAE,OAAO,ENrM1B,GAAO;;AMsMxB;gBACgC;EAAE,OAAO,ENtM1B,GAAO;;AMuMtB;iBACiC;EAAE,OAAO,ENvM1B,GAAO;;AMwMvB;iBACiC;EAAE,OAAO,ENxM1B,GAAO;;AMyMvB;wBACwC;EAAE,OAAO,ENxM1B,GAAO;;AMyM9B;mBACmC;EAAE,OAAO,EN3M1B,GAAO;;AM4MzB;oBACoC;EAAE,OAAO,EN3M1B,GAAO;;AM4M1B;0BAC0C;EAAE,OAAO,EN3M1B,GAAO;;AM4MhC;sBACsC;EAAE,OAAO,EN9M1B,GAAO;;AM+M5B;iBACiC;EAAE,OAAO,EN9M1B,GAAO;;AM+MvB;iBACiC;EAAE,OAAO,EN/M1B,GAAO;;AMgNvB;iBACiC;EAAE,OAAO,ENhN1B,GAAO;;AMiNvB;iBACiC;EAAE,OAAO,ENjN1B,GAAO;;AMkNvB;gBACgC;EAAE,OAAO,ENlN1B,GAAO;;AMmNtB;kBACkC;EAAE,OAAO,ENnN1B,GAAO;;AMoNxB;wBACwC;EAAE,OAAO,ENnN1B,GAAO;;AMoN9B;sBACsC;EAAE,OAAO,ENpN1B,GAAO;;AMqN5B;iBACiC;EAAE,OAAO,ENxN1B,GAAO;;AMyNvB;qBACqC;EAAE,OAAO,ENtN1B,GAAO;;AMuN3B;iBACiC;EAAE,OAAO,ENzN1B,GAAO;;AM0NvB;sBACsC;EAAE,OAAO,ENzN1B,GAAO;;AM0N5B;4BAC4C;EAAE,OAAO,EN1N1B,GAAO;;AM2NlC;uBACuC;EAAE,OAAO,EN3N1B,GAAO;;AM4N7B;0BAC0C;EAAE,OAAO,EN5N1B,GAAO;;AM6NhC;qBACqC;EAAE,OAAO,EN7N1B,GAAO;;AM8N3B;kBACkC;EAAE,OAAO,EN9N1B,GAAO;;AM+NxB;sBACsC;EAAE,OAAO,EN/N1B,GAAO;;AMgO5B;eAC+B;EAAE,OAAO,ENhO1B,GAAO;;AMiOrB;cAC8B;EAAE,OAAO,ENjO1B,GAAO;;AMkOpB;mBACmC;EAAE,OAAO,ENlO1B,GAAO;;AMmOzB;qBACqC;EAAE,OAAO,ENlO1B,GAAO;;AMmO3B;iBACiC;EAAE,OAAO,ENrO1B,GAAO;;AMsOvB;qBACqC;EAAE,OAAO,ENrO1B,GAAO;;AMsO3B;qBACqC;EAAE,OAAO,ENrO1B,GAAO;;AMsO3B;iBACiC;EAAE,OAAO,ENxO1B,GAAO;;AMyOvB;oBACoC;EAAE,OAAO,ENvO1B,GAAO;;AMwO1B;gBACgC;EAAE,OAAO,EN1O1B,GAAO;;AM2OtB;6BAC6C;EAAE,OAAO,ENzO1B,GAAO;;AM0OnC;wBACwC;EAAE,OAAO,EN5O1B,GAAO;;AM6O9B;oBACoC;EAAE,OAAO,EN5O1B,GAAO;;AM6O1B;iBACiC;EAAE,OAAO,EN7O1B,GAAO;;AM8OvB;gBACgC;EAAE,OAAO,EN9O1B,GAAO;;AM+OtB;qBACqC;EAAE,OAAO,EN/O1B,GAAO;;AMgP3B;qBACqC;EAAE,OAAO,EN/O1B,GAAO;;AMgP3B;iBACiC;EAAE,OAAO,ENlP1B,GAAO;;AMmPvB;qBACqC;EAAE,OAAO,ENlP1B,GAAO;;AMmP3B;kBACkC;EAAE,OAAO,ENnP1B,GAAO;;AMoPxB;kBACkC;EAAE,OAAO,ENpP1B,GAAO;;AMqPxB;wBACwC;EAAE,OAAO,ENrP1B,GAAO;;AMsP9B;mBACmC;EAAE,OAAO,ENrP1B,GAAO;;AMsPzB;qBACqC;EAAE,OAAO,ENtP1B,GAAO;;AMuP3B;eAC+B;EAAE,OAAO,EN1P1B,GAAO;;AM2PrB;wBACwC;EAAE,OAAO,ENzP1B,GAAO;;AM0P9B;uBACuC;EAAE,OAAO,EN1P1B,GAAO;;AM2P7B;mBACmC;EAAE,OAAO,EN1P1B,GAAO;;AM2PzB;eAC+B;EAAE,OAAO,EN7P1B,GAAO;;AM8PrB;sBACsC;EAAE,OAAO,EN7P1B,GAAO;;AM8P5B;cAC8B;EAAE,OAAO,EN9P1B,GAAO;;AM+PpB;eAC+B;EAAE,OAAO,EN/P1B,GAAO;;AMgQrB;gBACgC;EAAE,OAAO,ENhQ1B,GAAO;;AMiQtB;sBACsC;EAAE,OAAO,ENjQ1B,GAAO;;AMkQ5B;qBACqC;EAAE,OAAO,ENlQ1B,GAAO;;AMmQ3B;mBACmC;EAAE,OAAO,ENlQ1B,GAAO;;AMmQzB;kBACkC;EAAE,OAAO,ENnQ1B,GAAO;;AMoQxB;aAC6B;EAAE,OAAO,ENvQ1B,GAAO;;AMwQnB;sBACsC;EAAE,OAAO,ENtQ1B,GAAO;;AMuQ5B;oBACoC;EAAE,OAAO,ENvQ1B,GAAO;;AMwQ1B;mBACmC;EAAE,OAAO,ENvQ1B,GAAO;;AMwQzB;eAC+B;EAAE,OAAO,EN1Q1B,GAAO;;AM2QrB;eAC+B;EAAE,OAAO,EN1Q1B,GAAO;;AM2QrB;gBACgC;EAAE,OAAO,EN3Q1B,GAAO;;AM4QtB;oBACoC;EAAE,OAAO,EN3Q1B,GAAO;;AM4Q1B;gBACgC;EAAE,OAAO,EN9Q1B,GAAO;;AM+QtB;iBACiC;EAAE,OAAO,EN9Q1B,GAAO;;AM+QvB;kBACkC;EAAE,OAAO,EN/Q1B,GAAO;;AMgRxB;2BAC2C;EAAE,OAAO,ENhR1B,GAAO;;AMiRjC;qBACqC;EAAE,OAAO,ENhR1B,GAAO;;AMiR3B;iBACiC;EAAE,OAAO,ENnR1B,GAAO;;AMoRvB;iBACiC;EAAE,OAAO,ENnR1B,GAAO;;AMoRvB;cAC8B;EAAE,OAAO,ENpR1B,GAAO;;AMqRpB;eAC+B;EAAE,OAAO,ENrR1B,GAAO;;AMsRrB;iBACiC;EAAE,OAAO,ENtR1B,GAAO;;AMuRvB;oBACoC;EAAE,OAAO,ENtR1B,GAAO;;AMuR1B;qBACqC;EAAE,OAAO,ENvR1B,GAAO;;AMwR3B;gBACgC;EAAE,OAAO,EN3R1B,GAAO;;AM4RtB;oBACoC;EAAE,OAAO,EN1R1B,GAAO;;AM2R1B;gBACgC;EAAE,OAAO,EN3R1B,GAAO;;AM4RtB;oBACoC;EAAE,OAAO,EN5R1B,GAAO;;AM6R1B;sBACsC;EAAE,OAAO,EN7R1B,GAAO;;AM8R5B;qBACqC;EAAE,OAAO,EN9R1B,GAAO;;AM+R3B;oBACoC;EAAE,OAAO,EN/R1B,GAAO;;AMgS1B;cAC8B;EAAE,OAAO,ENhS1B,GAAO;;AMiSpB;uBACuC;EAAE,OAAO,ENjS1B,GAAO;;AMkS7B;sBACsC;EAAE,OAAO,ENjS1B,GAAO;;AMkS5B;kBACkC;EAAE,OAAO,ENpS1B,GAAO;;AMqSxB;qBACqC;EAAE,OAAO,ENpS1B,GAAO;;AMqS3B;oBACoC;EAAE,OAAO,ENrS1B,GAAO;;AMsS1B;qBACqC;EAAE,OAAO,ENrS1B,GAAO;;AMsS3B;iBACiC;EAAE,OAAO,ENxS1B,GAAO;;AMySvB;kBACkC;EAAE,OAAO,ENxS1B,GAAO;;AMySxB;kBACkC;EAAE,OAAO,ENzS1B,GAAO;;AM0SxB;mBACmC;EAAE,OAAO,EN1S1B,GAAO", -"sources": ["_path.scss","_core.scss","_larger.scss","_fixed-width.scss","_list.scss","_variables.scss","_bordered-pulled.scss","_animated.scss","_rotated-flipped.scss","_mixins.scss","_stacked.scss","_icons.scss"], -"names": [], -"file": "elusive-icons.css" -} \ No newline at end of file diff --git a/library/admin/ReduxCore/assets/css/vendor/elusive-icons/scss/elusive-icons.scss b/library/admin/ReduxCore/assets/css/vendor/elusive-icons/scss/elusive-icons.scss deleted file mode 100644 index c3bb7ba3..00000000 --- a/library/admin/ReduxCore/assets/css/vendor/elusive-icons/scss/elusive-icons.scss +++ /dev/null @@ -1,17 +0,0 @@ -/*! - * Elusive Icons 2.0.0 by @ReduxFramework - http://elusiveicons.com - @reduxframework - * License - http://elusiveicons.com/license (Font: SIL OFL 1.1, CSS: MIT License) - */ - -@import "variables"; -@import "mixins"; -@import "path"; -@import "core"; -@import "larger"; -@import "fixed-width"; -@import "list"; -@import "bordered-pulled"; -@import "animated"; -@import "rotated-flipped"; -@import "stacked"; -@import "icons"; diff --git a/library/admin/ReduxCore/assets/css/vendor/jquery-ui-bootstrap/images/ui-bg_flat_0_aaaaaa_40x100.png b/library/admin/ReduxCore/assets/css/vendor/jquery-ui-bootstrap/images/ui-bg_flat_0_aaaaaa_40x100.png deleted file mode 100644 index 5b5dab2a..00000000 Binary files a/library/admin/ReduxCore/assets/css/vendor/jquery-ui-bootstrap/images/ui-bg_flat_0_aaaaaa_40x100.png and /dev/null differ diff --git a/library/admin/ReduxCore/assets/css/vendor/jquery-ui-bootstrap/images/ui-bg_glass_55_fbf9ee_1x400.png b/library/admin/ReduxCore/assets/css/vendor/jquery-ui-bootstrap/images/ui-bg_glass_55_fbf9ee_1x400.png deleted file mode 100644 index ad3d6346..00000000 Binary files a/library/admin/ReduxCore/assets/css/vendor/jquery-ui-bootstrap/images/ui-bg_glass_55_fbf9ee_1x400.png and /dev/null differ diff --git a/library/admin/ReduxCore/assets/css/vendor/jquery-ui-bootstrap/images/ui-bg_glass_65_ffffff_1x400.png b/library/admin/ReduxCore/assets/css/vendor/jquery-ui-bootstrap/images/ui-bg_glass_65_ffffff_1x400.png deleted file mode 100644 index 42ccba26..00000000 Binary files a/library/admin/ReduxCore/assets/css/vendor/jquery-ui-bootstrap/images/ui-bg_glass_65_ffffff_1x400.png and /dev/null differ diff --git a/library/admin/ReduxCore/assets/css/vendor/jquery-ui-bootstrap/images/ui-bg_glass_75_dadada_1x400.png b/library/admin/ReduxCore/assets/css/vendor/jquery-ui-bootstrap/images/ui-bg_glass_75_dadada_1x400.png deleted file mode 100644 index 5a46b47c..00000000 Binary files a/library/admin/ReduxCore/assets/css/vendor/jquery-ui-bootstrap/images/ui-bg_glass_75_dadada_1x400.png and /dev/null differ diff --git a/library/admin/ReduxCore/assets/css/vendor/jquery-ui-bootstrap/images/ui-bg_glass_75_e6e6e6_1x400.png b/library/admin/ReduxCore/assets/css/vendor/jquery-ui-bootstrap/images/ui-bg_glass_75_e6e6e6_1x400.png deleted file mode 100644 index 86c2baa6..00000000 Binary files a/library/admin/ReduxCore/assets/css/vendor/jquery-ui-bootstrap/images/ui-bg_glass_75_e6e6e6_1x400.png and /dev/null differ diff --git a/library/admin/ReduxCore/assets/css/vendor/jquery-ui-bootstrap/images/ui-bg_glass_75_ffffff_1x400.png b/library/admin/ReduxCore/assets/css/vendor/jquery-ui-bootstrap/images/ui-bg_glass_75_ffffff_1x400.png deleted file mode 100644 index e65ca129..00000000 Binary files a/library/admin/ReduxCore/assets/css/vendor/jquery-ui-bootstrap/images/ui-bg_glass_75_ffffff_1x400.png and /dev/null differ diff --git a/library/admin/ReduxCore/assets/css/vendor/jquery-ui-bootstrap/images/ui-bg_highlight-soft_75_cccccc_1x100.png b/library/admin/ReduxCore/assets/css/vendor/jquery-ui-bootstrap/images/ui-bg_highlight-soft_75_cccccc_1x100.png deleted file mode 100644 index 7c9fa6c6..00000000 Binary files a/library/admin/ReduxCore/assets/css/vendor/jquery-ui-bootstrap/images/ui-bg_highlight-soft_75_cccccc_1x100.png and /dev/null differ diff --git a/library/admin/ReduxCore/assets/css/vendor/jquery-ui-bootstrap/images/ui-bg_inset-soft_95_fef1ec_1x100.png b/library/admin/ReduxCore/assets/css/vendor/jquery-ui-bootstrap/images/ui-bg_inset-soft_95_fef1ec_1x100.png deleted file mode 100644 index 0e05810f..00000000 Binary files a/library/admin/ReduxCore/assets/css/vendor/jquery-ui-bootstrap/images/ui-bg_inset-soft_95_fef1ec_1x100.png and /dev/null differ diff --git a/library/admin/ReduxCore/assets/css/vendor/jquery-ui-bootstrap/images/ui-icons_222222_256x240.png b/library/admin/ReduxCore/assets/css/vendor/jquery-ui-bootstrap/images/ui-icons_222222_256x240.png deleted file mode 100644 index b273ff11..00000000 Binary files a/library/admin/ReduxCore/assets/css/vendor/jquery-ui-bootstrap/images/ui-icons_222222_256x240.png and /dev/null differ diff --git a/library/admin/ReduxCore/assets/css/vendor/jquery-ui-bootstrap/images/ui-icons_2e83ff_256x240.png b/library/admin/ReduxCore/assets/css/vendor/jquery-ui-bootstrap/images/ui-icons_2e83ff_256x240.png deleted file mode 100644 index 09d1cdc8..00000000 Binary files a/library/admin/ReduxCore/assets/css/vendor/jquery-ui-bootstrap/images/ui-icons_2e83ff_256x240.png and /dev/null differ diff --git a/library/admin/ReduxCore/assets/css/vendor/jquery-ui-bootstrap/images/ui-icons_454545_256x240.png b/library/admin/ReduxCore/assets/css/vendor/jquery-ui-bootstrap/images/ui-icons_454545_256x240.png deleted file mode 100644 index 59bd45b9..00000000 Binary files a/library/admin/ReduxCore/assets/css/vendor/jquery-ui-bootstrap/images/ui-icons_454545_256x240.png and /dev/null differ diff --git a/library/admin/ReduxCore/assets/css/vendor/jquery-ui-bootstrap/images/ui-icons_888888_256x240.png b/library/admin/ReduxCore/assets/css/vendor/jquery-ui-bootstrap/images/ui-icons_888888_256x240.png deleted file mode 100644 index 6d02426c..00000000 Binary files a/library/admin/ReduxCore/assets/css/vendor/jquery-ui-bootstrap/images/ui-icons_888888_256x240.png and /dev/null differ diff --git a/library/admin/ReduxCore/assets/css/vendor/jquery-ui-bootstrap/images/ui-icons_cd0a0a_256x240.png b/library/admin/ReduxCore/assets/css/vendor/jquery-ui-bootstrap/images/ui-icons_cd0a0a_256x240.png deleted file mode 100644 index 2ab019b7..00000000 Binary files a/library/admin/ReduxCore/assets/css/vendor/jquery-ui-bootstrap/images/ui-icons_cd0a0a_256x240.png and /dev/null differ diff --git a/library/admin/ReduxCore/assets/css/vendor/jquery-ui-bootstrap/images/ui-icons_f6cf3b_256x240.png b/library/admin/ReduxCore/assets/css/vendor/jquery-ui-bootstrap/images/ui-icons_f6cf3b_256x240.png deleted file mode 100644 index c9869351..00000000 Binary files a/library/admin/ReduxCore/assets/css/vendor/jquery-ui-bootstrap/images/ui-icons_f6cf3b_256x240.png and /dev/null differ diff --git a/library/admin/ReduxCore/assets/css/vendor/jquery-ui-bootstrap/images/ui-icons_ffffff_256x240.png b/library/admin/ReduxCore/assets/css/vendor/jquery-ui-bootstrap/images/ui-icons_ffffff_256x240.png deleted file mode 100644 index 42f8f992..00000000 Binary files a/library/admin/ReduxCore/assets/css/vendor/jquery-ui-bootstrap/images/ui-icons_ffffff_256x240.png and /dev/null differ diff --git a/library/admin/ReduxCore/assets/css/vendor/jquery-ui-bootstrap/jquery-ui-1.10.0.custom.css b/library/admin/ReduxCore/assets/css/vendor/jquery-ui-bootstrap/jquery-ui-1.10.0.custom.css deleted file mode 100644 index 2ba22205..00000000 --- a/library/admin/ReduxCore/assets/css/vendor/jquery-ui-bootstrap/jquery-ui-1.10.0.custom.css +++ /dev/null @@ -1,9 +0,0 @@ -/*! - * jQuery UI Bootstrap (0.5) - * http://addyosmani.github.com/jquery-ui-bootstrap - * - * Copyright 2012 - 2013, Addy Osmani - * Dual licensed under the MIT or GPL Version 2 licenses. - * - * Portions copyright jQuery UI & Twitter Bootstrap - */.redux-container .ui-state-disabled,.control-section-redux .ui-state-disabled,.control-panel-redux .ui-state-disabled,.redux-metabox .ui-state-disabled{cursor:default !important}.redux-container .ui-icon,.control-section-redux .ui-icon,.control-panel-redux .ui-icon,.redux-metabox .ui-icon{display:block;text-indent:-99999px;overflow:hidden;background-repeat:no-repeat}.redux-container .ui-widget-content,.control-section-redux .ui-widget-content,.control-panel-redux .ui-widget-content,.redux-metabox .ui-widget-content{border:1px solid #aaaaaa;background:#fff url(images/ui-bg_glass_75_ffffff_1x400.png) 50% 50% repeat-x;color:#404040}.redux-container .ui-widget-header,.control-section-redux .ui-widget-header,.control-panel-redux .ui-widget-header,.redux-metabox .ui-widget-header{font-weight:bold;border-color:#0064cd #0064cd #003f81;border-color:rgba(0,0,0,0.1) rgba(0,0,0,0.1) rgba(0,0,0,0.25);border:1px solid #666}.redux-container .ui-widget-header a,.control-section-redux .ui-widget-header a,.control-panel-redux .ui-widget-header a,.redux-metabox .ui-widget-header a{color:#222222}.redux-container .ui-state-default,.redux-container .ui-widget-content .ui-state-default,.redux-container .ui-widget-header .ui-state-default,.control-section-redux .ui-state-default,.control-section-redux .ui-widget-content .ui-state-default,.control-section-redux .ui-widget-header .ui-state-default,.control-panel-redux .ui-state-default,.control-panel-redux .ui-widget-content .ui-state-default,.control-panel-redux .ui-widget-header .ui-state-default,.redux-metabox .ui-state-default,.redux-metabox .ui-widget-content .ui-state-default,.redux-metabox .ui-widget-header .ui-state-default{background-color:#e6e6e6;background-repeat:no-repeat;background-image:-webkit-gradient(linear, 0 0, 0 100%, from(#fff), color-stop(25%, #fff), to(#e6e6e6));background-image:-webkit-linear-gradient(#fff, #fff 25%, #e6e6e6);background-image:-moz-linear-gradient(top, #fff, #fff 25%, #e6e6e6);background-image:-ms-linear-gradient(#fff, #fff 25%, #e6e6e6);background-image:-o-linear-gradient(#fff, #fff 25%, #e6e6e6);background-image:linear-gradient(#fff, #fff 25%, #e6e6e6);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffffff', endColorstr='#e6e6e6', GradientType=0);text-shadow:0 1px 1px rgba(255,255,255,0.75);color:#333;font-size:13px;line-height:normal;border:1px solid #ccc;border-bottom-color:#bbb;-webkit-box-shadow:inset 0 1px 0 rgba(255,255,255,0.2),0 1px 2px rgba(0,0,0,0.05);-moz-box-shadow:inset 0 1px 0 rgba(255,255,255,0.2),0 1px 2px rgba(0,0,0,0.05);box-shadow:inset 0 1px 0 rgba(255,255,255,0.2),0 1px 2px rgba(0,0,0,0.05);-webkit-transition:0.1s linear background-image;-moz-transition:0.1s linear background-image;-ms-transition:0.1s linear background-image;-o-transition:0.1s linear background-image;transition:0.1s linear background-image;overflow:visible}.redux-container .ui-state-default a,.redux-container .ui-state-default a:link,.redux-container .ui-state-default a:visited,.control-section-redux .ui-state-default a,.control-section-redux .ui-state-default a:link,.control-section-redux .ui-state-default a:visited,.control-panel-redux .ui-state-default a,.control-panel-redux .ui-state-default a:link,.control-panel-redux .ui-state-default a:visited,.redux-metabox .ui-state-default a,.redux-metabox .ui-state-default a:link,.redux-metabox .ui-state-default a:visited{color:#555555;text-decoration:none}.redux-container .ui-state-hover,.redux-container .ui-widget-content .ui-state-hover,.redux-container .ui-widget-header .ui-state-hover,.redux-container .ui-state-focus,.redux-container .ui-widget-content .ui-state-focus,.redux-container .ui-widget-header .ui-state-focus,.control-section-redux .ui-state-hover,.control-section-redux .ui-widget-content .ui-state-hover,.control-section-redux .ui-widget-header .ui-state-hover,.control-section-redux .ui-state-focus,.control-section-redux .ui-widget-content .ui-state-focus,.control-section-redux .ui-widget-header .ui-state-focus,.control-panel-redux .ui-state-hover,.control-panel-redux .ui-widget-content .ui-state-hover,.control-panel-redux .ui-widget-header .ui-state-hover,.control-panel-redux .ui-state-focus,.control-panel-redux .ui-widget-content .ui-state-focus,.control-panel-redux .ui-widget-header .ui-state-focus,.redux-metabox .ui-state-hover,.redux-metabox .ui-widget-content .ui-state-hover,.redux-metabox .ui-widget-header .ui-state-hover,.redux-metabox .ui-state-focus,.redux-metabox .ui-widget-content .ui-state-focus,.redux-metabox .ui-widget-header .ui-state-focus{background-position:0 -15px;color:#333;text-decoration:none}.redux-container .ui-state-hover a,.redux-container .ui-state-hover a:hover,.redux-container .ui-state-hover a:link,.redux-container .ui-state-hover a:visited,.control-section-redux .ui-state-hover a,.control-section-redux .ui-state-hover a:hover,.control-section-redux .ui-state-hover a:link,.control-section-redux .ui-state-hover a:visited,.control-panel-redux .ui-state-hover a,.control-panel-redux .ui-state-hover a:hover,.control-panel-redux .ui-state-hover a:link,.control-panel-redux .ui-state-hover a:visited,.redux-metabox .ui-state-hover a,.redux-metabox .ui-state-hover a:hover,.redux-metabox .ui-state-hover a:link,.redux-metabox .ui-state-hover a:visited{color:#212121;text-decoration:none}.redux-container .ui-state-active,.redux-container .ui-widget-content .ui-state-active,.redux-container .ui-widget-header .ui-state-active,.control-section-redux .ui-state-active,.control-section-redux .ui-widget-content .ui-state-active,.control-section-redux .ui-widget-header .ui-state-active,.control-panel-redux .ui-state-active,.control-panel-redux .ui-widget-content .ui-state-active,.control-panel-redux .ui-widget-header .ui-state-active,.redux-metabox .ui-state-active,.redux-metabox .ui-widget-content .ui-state-active,.redux-metabox .ui-widget-header .ui-state-active{border:1px solid #aaaaaa;font-weight:normal;color:#212121}.redux-container .ui-state-active a,.redux-container .ui-state-active a:link,.redux-container .ui-state-active a:visited,.control-section-redux .ui-state-active a,.control-section-redux .ui-state-active a:link,.control-section-redux .ui-state-active a:visited,.control-panel-redux .ui-state-active a,.control-panel-redux .ui-state-active a:link,.control-panel-redux .ui-state-active a:visited,.redux-metabox .ui-state-active a,.redux-metabox .ui-state-active a:link,.redux-metabox .ui-state-active a:visited{color:#212121;text-decoration:none}.redux-container .ui-widget :active,.control-section-redux .ui-widget :active,.control-panel-redux .ui-widget :active,.redux-metabox .ui-widget :active{outline:none}.redux-container .ui-state-highlight p,.redux-container .ui-state-error p,.redux-container .ui-state-default p,.control-section-redux .ui-state-highlight p,.control-section-redux .ui-state-error p,.control-section-redux .ui-state-default p,.control-panel-redux .ui-state-highlight p,.control-panel-redux .ui-state-error p,.control-panel-redux .ui-state-default p,.redux-metabox .ui-state-highlight p,.redux-metabox .ui-state-error p,.redux-metabox .ui-state-default p{font-size:13px;font-weight:normal;line-height:18px;margin:7px 15px}.redux-container .ui-state-highlight,.redux-container .ui-widget-content .ui-state-highlight,.redux-container .ui-widget-header .ui-state-highlight,.control-section-redux .ui-state-highlight,.control-section-redux .ui-widget-content .ui-state-highlight,.control-section-redux .ui-widget-header .ui-state-highlight,.control-panel-redux .ui-state-highlight,.control-panel-redux .ui-widget-content .ui-state-highlight,.control-panel-redux .ui-widget-header .ui-state-highlight,.redux-metabox .ui-state-highlight,.redux-metabox .ui-widget-content .ui-state-highlight,.redux-metabox .ui-widget-header .ui-state-highlight{position:relative;margin-bottom:18px;color:#404040;background-color:#eedc94;background-repeat:repeat-x;background-image:-khtml-gradient(linear, left top, left bottom, from(#fceec1), to(#eedc94));background-image:-moz-linear-gradient(top, #fceec1, #eedc94);background-image:-ms-linear-gradient(top, #fceec1, #eedc94);background-image:-webkit-gradient(linear, left top, left bottom, color-stop(0%, #fceec1), color-stop(100%, #eedc94));background-image:-webkit-linear-gradient(top, #fceec1, #eedc94);background-image:-o-linear-gradient(top, #fceec1, #eedc94);background-image:linear-gradient(top, #fceec1, #eedc94);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#fceec1', endColorstr='#eedc94', GradientType=0);text-shadow:0 -1px 0 rgba(0,0,0,0.25);border-color:#eedc94 #eedc94 #e4c652;border-color:rgba(0,0,0,0.1) rgba(0,0,0,0.1) rgba(0,0,0,0.25);text-shadow:0 1px 0 rgba(255,255,255,0.5);border-width:1px;border-style:solid;-webkit-border-radius:4px;-moz-border-radius:4px;border-radius:4px;-webkit-box-shadow:inset 0 1px 0 rgba(255,255,255,0.25);-moz-box-shadow:inset 0 1px 0 rgba(255,255,255,0.25);box-shadow:inset 0 1px 0 rgba(255,255,255,0.25)}.redux-container .ui-state-highlight a,.redux-container .ui-widget-content .ui-state-highlight a,.redux-container .ui-widget-header .ui-state-highlight a,.control-section-redux .ui-state-highlight a,.control-section-redux .ui-widget-content .ui-state-highlight a,.control-section-redux .ui-widget-header .ui-state-highlight a,.control-panel-redux .ui-state-highlight a,.control-panel-redux .ui-widget-content .ui-state-highlight a,.control-panel-redux .ui-widget-header .ui-state-highlight a,.redux-metabox .ui-state-highlight a,.redux-metabox .ui-widget-content .ui-state-highlight a,.redux-metabox .ui-widget-header .ui-state-highlight a{color:#363636}.redux-container .ui-state-error,.redux-container .ui-widget-content .ui-state-error,.redux-container .ui-widget-header .ui-state-error,.control-section-redux .ui-state-error,.control-section-redux .ui-widget-content .ui-state-error,.control-section-redux .ui-widget-header .ui-state-error,.control-panel-redux .ui-state-error,.control-panel-redux .ui-widget-content .ui-state-error,.control-panel-redux .ui-widget-header .ui-state-error,.redux-metabox .ui-state-error,.redux-metabox .ui-widget-content .ui-state-error,.redux-metabox .ui-widget-header .ui-state-error{position:relative;margin-bottom:18px;color:#ffffff;border-width:1px;border-style:solid;-webkit-border-radius:4px;-moz-border-radius:4px;border-radius:4px;-webkit-box-shadow:inset 0 1px 0 rgba(255,255,255,0.25);-moz-box-shadow:inset 0 1px 0 rgba(255,255,255,0.25);box-shadow:inset 0 1px 0 rgba(255,255,255,0.25);background-color:#c43c35;background-repeat:repeat-x;background-image:-khtml-gradient(linear, left top, left bottom, from(#ee5f5b), to(#c43c35));background-image:-moz-linear-gradient(top, #ee5f5b, #c43c35);background-image:-ms-linear-gradient(top, #ee5f5b, #c43c35);background-image:-webkit-gradient(linear, left top, left bottom, color-stop(0%, #ee5f5b), color-stop(100%, #c43c35));background-image:-webkit-linear-gradient(top, #ee5f5b, #c43c35);background-image:-o-linear-gradient(top, #ee5f5b, #c43c35);background-image:linear-gradient(top, #ee5f5b, #c43c35);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#ee5f5b', endColorstr='#c43c35', GradientType=0);text-shadow:0 -1px 0 rgba(0,0,0,0.25);border-color:#c43c35 #c43c35 #882a25;border-color:rgba(0,0,0,0.1) rgba(0,0,0,0.1) rgba(0,0,0,0.25)}.redux-container .ui-state-error a,.redux-container .ui-widget-content .ui-state-error a,.redux-container .ui-widget-header .ui-state-error a,.control-section-redux .ui-state-error a,.control-section-redux .ui-widget-content .ui-state-error a,.control-section-redux .ui-widget-header .ui-state-error a,.control-panel-redux .ui-state-error a,.control-panel-redux .ui-widget-content .ui-state-error a,.control-panel-redux .ui-widget-header .ui-state-error a,.redux-metabox .ui-state-error a,.redux-metabox .ui-widget-content .ui-state-error a,.redux-metabox .ui-widget-header .ui-state-error a{color:#cd0a0a}.redux-container .ui-state-error-text,.redux-container .ui-widget-content .ui-state-error-text,.redux-container .ui-widget-header .ui-state-error-text,.control-section-redux .ui-state-error-text,.control-section-redux .ui-widget-content .ui-state-error-text,.control-section-redux .ui-widget-header .ui-state-error-text,.control-panel-redux .ui-state-error-text,.control-panel-redux .ui-widget-content .ui-state-error-text,.control-panel-redux .ui-widget-header .ui-state-error-text,.redux-metabox .ui-state-error-text,.redux-metabox .ui-widget-content .ui-state-error-text,.redux-metabox .ui-widget-header .ui-state-error-text{color:#cd0a0a}.redux-container .ui-priority-primary,.redux-container .ui-widget-content .ui-priority-primary,.redux-container .ui-widget-header .ui-priority-primary,.control-section-redux .ui-priority-primary,.control-section-redux .ui-widget-content .ui-priority-primary,.control-section-redux .ui-widget-header .ui-priority-primary,.control-panel-redux .ui-priority-primary,.control-panel-redux .ui-widget-content .ui-priority-primary,.control-panel-redux .ui-widget-header .ui-priority-primary,.redux-metabox .ui-priority-primary,.redux-metabox .ui-widget-content .ui-priority-primary,.redux-metabox .ui-widget-header .ui-priority-primary{font-weight:bold}.redux-container .ui-priority-secondary,.redux-container .ui-widget-content .ui-priority-secondary,.redux-container .ui-widget-header .ui-priority-secondary,.control-section-redux .ui-priority-secondary,.control-section-redux .ui-widget-content .ui-priority-secondary,.control-section-redux .ui-widget-header .ui-priority-secondary,.control-panel-redux .ui-priority-secondary,.control-panel-redux .ui-widget-content .ui-priority-secondary,.control-panel-redux .ui-widget-header .ui-priority-secondary,.redux-metabox .ui-priority-secondary,.redux-metabox .ui-widget-content .ui-priority-secondary,.redux-metabox .ui-widget-header .ui-priority-secondary{opacity:.7;filter:Alpha(Opacity=70);font-weight:normal}.redux-container .ui-state-disabled,.redux-container .ui-widget-content .ui-state-disabled,.redux-container .ui-widget-header .ui-state-disabled,.control-section-redux .ui-state-disabled,.control-section-redux .ui-widget-content .ui-state-disabled,.control-section-redux .ui-widget-header .ui-state-disabled,.control-panel-redux .ui-state-disabled,.control-panel-redux .ui-widget-content .ui-state-disabled,.control-panel-redux .ui-widget-header .ui-state-disabled,.redux-metabox .ui-state-disabled,.redux-metabox .ui-widget-content .ui-state-disabled,.redux-metabox .ui-widget-header .ui-state-disabled{opacity:.35;filter:Alpha(Opacity=35);background-image:none}.redux-container .ui-state-disabled .ui-icon,.control-section-redux .ui-state-disabled .ui-icon,.control-panel-redux .ui-state-disabled .ui-icon,.redux-metabox .ui-state-disabled .ui-icon{filter:Alpha(Opacity=35)}.redux-container .ui-icon,.control-section-redux .ui-icon,.control-panel-redux .ui-icon,.redux-metabox .ui-icon{width:16px;height:16px;background-image:url(images/ui-icons_222222_256x240.png)}.redux-container .ui-widget-content .ui-icon,.control-section-redux .ui-widget-content .ui-icon,.control-panel-redux .ui-widget-content .ui-icon,.redux-metabox .ui-widget-content .ui-icon{background-image:url(images/ui-icons_222222_256x240.png)}.redux-container .ui-widget-header .ui-icon,.control-section-redux .ui-widget-header .ui-icon,.control-panel-redux .ui-widget-header .ui-icon,.redux-metabox .ui-widget-header .ui-icon{background-image:url(images/ui-icons_222222_256x240.png)}.redux-container .ui-state-default .ui-icon,.control-section-redux .ui-state-default .ui-icon,.control-panel-redux .ui-state-default .ui-icon,.redux-metabox .ui-state-default .ui-icon{background-image:url(images/ui-icons_888888_256x240.png)}.redux-container .ui-state-hover .ui-icon,.redux-container .ui-state-focus .ui-icon,.control-section-redux .ui-state-hover .ui-icon,.control-section-redux .ui-state-focus .ui-icon,.control-panel-redux .ui-state-hover .ui-icon,.control-panel-redux .ui-state-focus .ui-icon,.redux-metabox .ui-state-hover .ui-icon,.redux-metabox .ui-state-focus .ui-icon{background-image:url(images/ui-icons_454545_256x240.png)}.redux-container .ui-state-active .ui-icon,.control-section-redux .ui-state-active .ui-icon,.control-panel-redux .ui-state-active .ui-icon,.redux-metabox .ui-state-active .ui-icon{background-image:url(images/ui-icons_454545_256x240.png)}.redux-container .ui-state-highlight .ui-icon,.control-section-redux .ui-state-highlight .ui-icon,.control-panel-redux .ui-state-highlight .ui-icon,.redux-metabox .ui-state-highlight .ui-icon{background-image:url(images/ui-icons_2e83ff_256x240.png)}.redux-container .ui-state-error .ui-icon,.redux-container .ui-state-error-text .ui-icon,.control-section-redux .ui-state-error .ui-icon,.control-section-redux .ui-state-error-text .ui-icon,.control-panel-redux .ui-state-error .ui-icon,.control-panel-redux .ui-state-error-text .ui-icon,.redux-metabox .ui-state-error .ui-icon,.redux-metabox .ui-state-error-text .ui-icon{background-image:url(images/ui-icons_f6cf3b_256x240.png)}.redux-container .ui-icon-carat-1-n,.control-section-redux .ui-icon-carat-1-n,.control-panel-redux .ui-icon-carat-1-n,.redux-metabox .ui-icon-carat-1-n{background-position:0 0}.redux-container .ui-icon-carat-1-ne,.control-section-redux .ui-icon-carat-1-ne,.control-panel-redux .ui-icon-carat-1-ne,.redux-metabox .ui-icon-carat-1-ne{background-position:-16px 0}.redux-container .ui-icon-carat-1-e,.control-section-redux .ui-icon-carat-1-e,.control-panel-redux .ui-icon-carat-1-e,.redux-metabox .ui-icon-carat-1-e{background-position:-32px 0}.redux-container .ui-icon-carat-1-se,.control-section-redux .ui-icon-carat-1-se,.control-panel-redux .ui-icon-carat-1-se,.redux-metabox .ui-icon-carat-1-se{background-position:-48px 0}.redux-container .ui-icon-carat-1-s,.control-section-redux .ui-icon-carat-1-s,.control-panel-redux .ui-icon-carat-1-s,.redux-metabox .ui-icon-carat-1-s{background-position:-64px 0}.redux-container .ui-icon-carat-1-sw,.control-section-redux .ui-icon-carat-1-sw,.control-panel-redux .ui-icon-carat-1-sw,.redux-metabox .ui-icon-carat-1-sw{background-position:-80px 0}.redux-container .ui-icon-carat-1-w,.control-section-redux .ui-icon-carat-1-w,.control-panel-redux .ui-icon-carat-1-w,.redux-metabox .ui-icon-carat-1-w{background-position:-96px 0}.redux-container .ui-icon-carat-1-nw,.control-section-redux .ui-icon-carat-1-nw,.control-panel-redux .ui-icon-carat-1-nw,.redux-metabox .ui-icon-carat-1-nw{background-position:-112px 0}.redux-container .ui-icon-carat-2-n-s,.control-section-redux .ui-icon-carat-2-n-s,.control-panel-redux .ui-icon-carat-2-n-s,.redux-metabox .ui-icon-carat-2-n-s{background-position:-128px 0}.redux-container .ui-icon-carat-2-e-w,.control-section-redux .ui-icon-carat-2-e-w,.control-panel-redux .ui-icon-carat-2-e-w,.redux-metabox .ui-icon-carat-2-e-w{background-position:-144px 0}.redux-container .ui-icon-triangle-1-n,.control-section-redux .ui-icon-triangle-1-n,.control-panel-redux .ui-icon-triangle-1-n,.redux-metabox .ui-icon-triangle-1-n{background-position:0 -16px}.redux-container .ui-icon-triangle-1-ne,.control-section-redux .ui-icon-triangle-1-ne,.control-panel-redux .ui-icon-triangle-1-ne,.redux-metabox .ui-icon-triangle-1-ne{background-position:-16px -16px}.redux-container .ui-icon-triangle-1-e,.control-section-redux .ui-icon-triangle-1-e,.control-panel-redux .ui-icon-triangle-1-e,.redux-metabox .ui-icon-triangle-1-e{background-position:-32px -16px}.redux-container .ui-icon-triangle-1-se,.control-section-redux .ui-icon-triangle-1-se,.control-panel-redux .ui-icon-triangle-1-se,.redux-metabox .ui-icon-triangle-1-se{background-position:-48px -16px}.redux-container .ui-icon-triangle-1-s,.control-section-redux .ui-icon-triangle-1-s,.control-panel-redux .ui-icon-triangle-1-s,.redux-metabox .ui-icon-triangle-1-s{background-position:-64px -16px}.redux-container .ui-icon-triangle-1-sw,.control-section-redux .ui-icon-triangle-1-sw,.control-panel-redux .ui-icon-triangle-1-sw,.redux-metabox .ui-icon-triangle-1-sw{background-position:-80px -16px}.redux-container .ui-icon-triangle-1-w,.control-section-redux .ui-icon-triangle-1-w,.control-panel-redux .ui-icon-triangle-1-w,.redux-metabox .ui-icon-triangle-1-w{background-position:-96px -16px}.redux-container .ui-icon-triangle-1-nw,.control-section-redux .ui-icon-triangle-1-nw,.control-panel-redux .ui-icon-triangle-1-nw,.redux-metabox .ui-icon-triangle-1-nw{background-position:-112px -16px}.redux-container .ui-icon-triangle-2-n-s,.control-section-redux .ui-icon-triangle-2-n-s,.control-panel-redux .ui-icon-triangle-2-n-s,.redux-metabox .ui-icon-triangle-2-n-s{background-position:-128px -16px}.redux-container .ui-icon-triangle-2-e-w,.control-section-redux .ui-icon-triangle-2-e-w,.control-panel-redux .ui-icon-triangle-2-e-w,.redux-metabox .ui-icon-triangle-2-e-w{background-position:-144px -16px}.redux-container .ui-icon-arrow-1-n,.control-section-redux .ui-icon-arrow-1-n,.control-panel-redux .ui-icon-arrow-1-n,.redux-metabox .ui-icon-arrow-1-n{background-position:0 -32px}.redux-container .ui-icon-arrow-1-ne,.control-section-redux .ui-icon-arrow-1-ne,.control-panel-redux .ui-icon-arrow-1-ne,.redux-metabox .ui-icon-arrow-1-ne{background-position:-16px -32px}.redux-container .ui-icon-arrow-1-e,.control-section-redux .ui-icon-arrow-1-e,.control-panel-redux .ui-icon-arrow-1-e,.redux-metabox .ui-icon-arrow-1-e{background-position:-32px -32px}.redux-container .ui-icon-arrow-1-se,.control-section-redux .ui-icon-arrow-1-se,.control-panel-redux .ui-icon-arrow-1-se,.redux-metabox .ui-icon-arrow-1-se{background-position:-48px -32px}.redux-container .ui-icon-arrow-1-s,.control-section-redux .ui-icon-arrow-1-s,.control-panel-redux .ui-icon-arrow-1-s,.redux-metabox .ui-icon-arrow-1-s{background-position:-64px -32px}.redux-container .ui-icon-arrow-1-sw,.control-section-redux .ui-icon-arrow-1-sw,.control-panel-redux .ui-icon-arrow-1-sw,.redux-metabox .ui-icon-arrow-1-sw{background-position:-80px -32px}.redux-container .ui-icon-arrow-1-w,.control-section-redux .ui-icon-arrow-1-w,.control-panel-redux .ui-icon-arrow-1-w,.redux-metabox .ui-icon-arrow-1-w{background-position:-96px -32px}.redux-container .ui-icon-arrow-1-nw,.control-section-redux .ui-icon-arrow-1-nw,.control-panel-redux .ui-icon-arrow-1-nw,.redux-metabox .ui-icon-arrow-1-nw{background-position:-112px -32px}.redux-container .ui-icon-arrow-2-n-s,.control-section-redux .ui-icon-arrow-2-n-s,.control-panel-redux .ui-icon-arrow-2-n-s,.redux-metabox .ui-icon-arrow-2-n-s{background-position:-128px -32px}.redux-container .ui-icon-arrow-2-ne-sw,.control-section-redux .ui-icon-arrow-2-ne-sw,.control-panel-redux .ui-icon-arrow-2-ne-sw,.redux-metabox .ui-icon-arrow-2-ne-sw{background-position:-144px -32px}.redux-container .ui-icon-arrow-2-e-w,.control-section-redux .ui-icon-arrow-2-e-w,.control-panel-redux .ui-icon-arrow-2-e-w,.redux-metabox .ui-icon-arrow-2-e-w{background-position:-160px -32px}.redux-container .ui-icon-arrow-2-se-nw,.control-section-redux .ui-icon-arrow-2-se-nw,.control-panel-redux .ui-icon-arrow-2-se-nw,.redux-metabox .ui-icon-arrow-2-se-nw{background-position:-176px -32px}.redux-container .ui-icon-arrowstop-1-n,.control-section-redux .ui-icon-arrowstop-1-n,.control-panel-redux .ui-icon-arrowstop-1-n,.redux-metabox .ui-icon-arrowstop-1-n{background-position:-192px -32px}.redux-container .ui-icon-arrowstop-1-e,.control-section-redux .ui-icon-arrowstop-1-e,.control-panel-redux .ui-icon-arrowstop-1-e,.redux-metabox .ui-icon-arrowstop-1-e{background-position:-208px -32px}.redux-container .ui-icon-arrowstop-1-s,.control-section-redux .ui-icon-arrowstop-1-s,.control-panel-redux .ui-icon-arrowstop-1-s,.redux-metabox .ui-icon-arrowstop-1-s{background-position:-224px -32px}.redux-container .ui-icon-arrowstop-1-w,.control-section-redux .ui-icon-arrowstop-1-w,.control-panel-redux .ui-icon-arrowstop-1-w,.redux-metabox .ui-icon-arrowstop-1-w{background-position:-240px -32px}.redux-container .ui-icon-arrowthick-1-n,.control-section-redux .ui-icon-arrowthick-1-n,.control-panel-redux .ui-icon-arrowthick-1-n,.redux-metabox .ui-icon-arrowthick-1-n{background-position:0 -48px}.redux-container .ui-icon-arrowthick-1-ne,.control-section-redux .ui-icon-arrowthick-1-ne,.control-panel-redux .ui-icon-arrowthick-1-ne,.redux-metabox .ui-icon-arrowthick-1-ne{background-position:-16px -48px}.redux-container .ui-icon-arrowthick-1-e,.control-section-redux .ui-icon-arrowthick-1-e,.control-panel-redux .ui-icon-arrowthick-1-e,.redux-metabox .ui-icon-arrowthick-1-e{background-position:-32px -48px}.redux-container .ui-icon-arrowthick-1-se,.control-section-redux .ui-icon-arrowthick-1-se,.control-panel-redux .ui-icon-arrowthick-1-se,.redux-metabox .ui-icon-arrowthick-1-se{background-position:-48px -48px}.redux-container .ui-icon-arrowthick-1-s,.control-section-redux .ui-icon-arrowthick-1-s,.control-panel-redux .ui-icon-arrowthick-1-s,.redux-metabox .ui-icon-arrowthick-1-s{background-position:-64px -48px}.redux-container .ui-icon-arrowthick-1-sw,.control-section-redux .ui-icon-arrowthick-1-sw,.control-panel-redux .ui-icon-arrowthick-1-sw,.redux-metabox .ui-icon-arrowthick-1-sw{background-position:-80px -48px}.redux-container .ui-icon-arrowthick-1-w,.control-section-redux .ui-icon-arrowthick-1-w,.control-panel-redux .ui-icon-arrowthick-1-w,.redux-metabox .ui-icon-arrowthick-1-w{background-position:-96px -48px}.redux-container .ui-icon-arrowthick-1-nw,.control-section-redux .ui-icon-arrowthick-1-nw,.control-panel-redux .ui-icon-arrowthick-1-nw,.redux-metabox .ui-icon-arrowthick-1-nw{background-position:-112px -48px}.redux-container .ui-icon-arrowthick-2-n-s,.control-section-redux .ui-icon-arrowthick-2-n-s,.control-panel-redux .ui-icon-arrowthick-2-n-s,.redux-metabox .ui-icon-arrowthick-2-n-s{background-position:-128px -48px}.redux-container .ui-icon-arrowthick-2-ne-sw,.control-section-redux .ui-icon-arrowthick-2-ne-sw,.control-panel-redux .ui-icon-arrowthick-2-ne-sw,.redux-metabox .ui-icon-arrowthick-2-ne-sw{background-position:-144px -48px}.redux-container .ui-icon-arrowthick-2-e-w,.control-section-redux .ui-icon-arrowthick-2-e-w,.control-panel-redux .ui-icon-arrowthick-2-e-w,.redux-metabox .ui-icon-arrowthick-2-e-w{background-position:-160px -48px}.redux-container .ui-icon-arrowthick-2-se-nw,.control-section-redux .ui-icon-arrowthick-2-se-nw,.control-panel-redux .ui-icon-arrowthick-2-se-nw,.redux-metabox .ui-icon-arrowthick-2-se-nw{background-position:-176px -48px}.redux-container .ui-icon-arrowthickstop-1-n,.control-section-redux .ui-icon-arrowthickstop-1-n,.control-panel-redux .ui-icon-arrowthickstop-1-n,.redux-metabox .ui-icon-arrowthickstop-1-n{background-position:-192px -48px}.redux-container .ui-icon-arrowthickstop-1-e,.control-section-redux .ui-icon-arrowthickstop-1-e,.control-panel-redux .ui-icon-arrowthickstop-1-e,.redux-metabox .ui-icon-arrowthickstop-1-e{background-position:-208px -48px}.redux-container .ui-icon-arrowthickstop-1-s,.control-section-redux .ui-icon-arrowthickstop-1-s,.control-panel-redux .ui-icon-arrowthickstop-1-s,.redux-metabox .ui-icon-arrowthickstop-1-s{background-position:-224px -48px}.redux-container .ui-icon-arrowthickstop-1-w,.control-section-redux .ui-icon-arrowthickstop-1-w,.control-panel-redux .ui-icon-arrowthickstop-1-w,.redux-metabox .ui-icon-arrowthickstop-1-w{background-position:-240px -48px}.redux-container .ui-icon-arrowreturnthick-1-w,.control-section-redux .ui-icon-arrowreturnthick-1-w,.control-panel-redux .ui-icon-arrowreturnthick-1-w,.redux-metabox .ui-icon-arrowreturnthick-1-w{background-position:0 -64px}.redux-container .ui-icon-arrowreturnthick-1-n,.control-section-redux .ui-icon-arrowreturnthick-1-n,.control-panel-redux .ui-icon-arrowreturnthick-1-n,.redux-metabox .ui-icon-arrowreturnthick-1-n{background-position:-16px -64px}.redux-container .ui-icon-arrowreturnthick-1-e,.control-section-redux .ui-icon-arrowreturnthick-1-e,.control-panel-redux .ui-icon-arrowreturnthick-1-e,.redux-metabox .ui-icon-arrowreturnthick-1-e{background-position:-32px -64px}.redux-container .ui-icon-arrowreturnthick-1-s,.control-section-redux .ui-icon-arrowreturnthick-1-s,.control-panel-redux .ui-icon-arrowreturnthick-1-s,.redux-metabox .ui-icon-arrowreturnthick-1-s{background-position:-48px -64px}.redux-container .ui-icon-arrowreturn-1-w,.control-section-redux .ui-icon-arrowreturn-1-w,.control-panel-redux .ui-icon-arrowreturn-1-w,.redux-metabox .ui-icon-arrowreturn-1-w{background-position:-64px -64px}.redux-container .ui-icon-arrowreturn-1-n,.control-section-redux .ui-icon-arrowreturn-1-n,.control-panel-redux .ui-icon-arrowreturn-1-n,.redux-metabox .ui-icon-arrowreturn-1-n{background-position:-80px -64px}.redux-container .ui-icon-arrowreturn-1-e,.control-section-redux .ui-icon-arrowreturn-1-e,.control-panel-redux .ui-icon-arrowreturn-1-e,.redux-metabox .ui-icon-arrowreturn-1-e{background-position:-96px -64px}.redux-container .ui-icon-arrowreturn-1-s,.control-section-redux .ui-icon-arrowreturn-1-s,.control-panel-redux .ui-icon-arrowreturn-1-s,.redux-metabox .ui-icon-arrowreturn-1-s{background-position:-112px -64px}.redux-container .ui-icon-arrowrefresh-1-w,.control-section-redux .ui-icon-arrowrefresh-1-w,.control-panel-redux .ui-icon-arrowrefresh-1-w,.redux-metabox .ui-icon-arrowrefresh-1-w{background-position:-128px -64px}.redux-container .ui-icon-arrowrefresh-1-n,.control-section-redux .ui-icon-arrowrefresh-1-n,.control-panel-redux .ui-icon-arrowrefresh-1-n,.redux-metabox .ui-icon-arrowrefresh-1-n{background-position:-144px -64px}.redux-container .ui-icon-arrowrefresh-1-e,.control-section-redux .ui-icon-arrowrefresh-1-e,.control-panel-redux .ui-icon-arrowrefresh-1-e,.redux-metabox .ui-icon-arrowrefresh-1-e{background-position:-160px -64px}.redux-container .ui-icon-arrowrefresh-1-s,.control-section-redux .ui-icon-arrowrefresh-1-s,.control-panel-redux .ui-icon-arrowrefresh-1-s,.redux-metabox .ui-icon-arrowrefresh-1-s{background-position:-176px -64px}.redux-container .ui-icon-arrow-4,.control-section-redux .ui-icon-arrow-4,.control-panel-redux .ui-icon-arrow-4,.redux-metabox .ui-icon-arrow-4{background-position:0 -80px}.redux-container .ui-icon-arrow-4-diag,.control-section-redux .ui-icon-arrow-4-diag,.control-panel-redux .ui-icon-arrow-4-diag,.redux-metabox .ui-icon-arrow-4-diag{background-position:-16px -80px}.redux-container .ui-icon-extlink,.control-section-redux .ui-icon-extlink,.control-panel-redux .ui-icon-extlink,.redux-metabox .ui-icon-extlink{background-position:-32px -80px}.redux-container .ui-icon-newwin,.control-section-redux .ui-icon-newwin,.control-panel-redux .ui-icon-newwin,.redux-metabox .ui-icon-newwin{background-position:-48px -80px}.redux-container .ui-icon-refresh,.control-section-redux .ui-icon-refresh,.control-panel-redux .ui-icon-refresh,.redux-metabox .ui-icon-refresh{background-position:-64px -80px}.redux-container .ui-icon-shuffle,.control-section-redux .ui-icon-shuffle,.control-panel-redux .ui-icon-shuffle,.redux-metabox .ui-icon-shuffle{background-position:-80px -80px}.redux-container .ui-icon-transfer-e-w,.control-section-redux .ui-icon-transfer-e-w,.control-panel-redux .ui-icon-transfer-e-w,.redux-metabox .ui-icon-transfer-e-w{background-position:-96px -80px}.redux-container .ui-icon-transferthick-e-w,.control-section-redux .ui-icon-transferthick-e-w,.control-panel-redux .ui-icon-transferthick-e-w,.redux-metabox .ui-icon-transferthick-e-w{background-position:-112px -80px}.redux-container .ui-icon-folder-collapsed,.control-section-redux .ui-icon-folder-collapsed,.control-panel-redux .ui-icon-folder-collapsed,.redux-metabox .ui-icon-folder-collapsed{background-position:0 -96px}.redux-container .ui-icon-folder-open,.control-section-redux .ui-icon-folder-open,.control-panel-redux .ui-icon-folder-open,.redux-metabox .ui-icon-folder-open{background-position:-16px -96px}.redux-container .ui-icon-document,.control-section-redux .ui-icon-document,.control-panel-redux .ui-icon-document,.redux-metabox .ui-icon-document{background-position:-32px -96px}.redux-container .ui-icon-document-b,.control-section-redux .ui-icon-document-b,.control-panel-redux .ui-icon-document-b,.redux-metabox .ui-icon-document-b{background-position:-48px -96px}.redux-container .ui-icon-note,.control-section-redux .ui-icon-note,.control-panel-redux .ui-icon-note,.redux-metabox .ui-icon-note{background-position:-64px -96px}.redux-container .ui-icon-mail-closed,.control-section-redux .ui-icon-mail-closed,.control-panel-redux .ui-icon-mail-closed,.redux-metabox .ui-icon-mail-closed{background-position:-80px -96px}.redux-container .ui-icon-mail-open,.control-section-redux .ui-icon-mail-open,.control-panel-redux .ui-icon-mail-open,.redux-metabox .ui-icon-mail-open{background-position:-96px -96px}.redux-container .ui-icon-suitcase,.control-section-redux .ui-icon-suitcase,.control-panel-redux .ui-icon-suitcase,.redux-metabox .ui-icon-suitcase{background-position:-112px -96px}.redux-container .ui-icon-comment,.control-section-redux .ui-icon-comment,.control-panel-redux .ui-icon-comment,.redux-metabox .ui-icon-comment{background-position:-128px -96px}.redux-container .ui-icon-person,.control-section-redux .ui-icon-person,.control-panel-redux .ui-icon-person,.redux-metabox .ui-icon-person{background-position:-144px -96px}.redux-container .ui-icon-print,.control-section-redux .ui-icon-print,.control-panel-redux .ui-icon-print,.redux-metabox .ui-icon-print{background-position:-160px -96px}.redux-container .ui-icon-trash,.control-section-redux .ui-icon-trash,.control-panel-redux .ui-icon-trash,.redux-metabox .ui-icon-trash{background-position:-176px -96px}.redux-container .ui-icon-locked,.control-section-redux .ui-icon-locked,.control-panel-redux .ui-icon-locked,.redux-metabox .ui-icon-locked{background-position:-192px -96px}.redux-container .ui-icon-unlocked,.control-section-redux .ui-icon-unlocked,.control-panel-redux .ui-icon-unlocked,.redux-metabox .ui-icon-unlocked{background-position:-208px -96px}.redux-container .ui-icon-bookmark,.control-section-redux .ui-icon-bookmark,.control-panel-redux .ui-icon-bookmark,.redux-metabox .ui-icon-bookmark{background-position:-224px -96px}.redux-container .ui-icon-tag,.control-section-redux .ui-icon-tag,.control-panel-redux .ui-icon-tag,.redux-metabox .ui-icon-tag{background-position:-240px -96px}.redux-container .ui-icon-home,.control-section-redux .ui-icon-home,.control-panel-redux .ui-icon-home,.redux-metabox .ui-icon-home{background-position:0 -112px}.redux-container .ui-icon-flag,.control-section-redux .ui-icon-flag,.control-panel-redux .ui-icon-flag,.redux-metabox .ui-icon-flag{background-position:-16px -112px}.redux-container .ui-icon-calendar,.control-section-redux .ui-icon-calendar,.control-panel-redux .ui-icon-calendar,.redux-metabox .ui-icon-calendar{background-position:-32px -112px}.redux-container .ui-icon-cart,.control-section-redux .ui-icon-cart,.control-panel-redux .ui-icon-cart,.redux-metabox .ui-icon-cart{background-position:-48px -112px}.redux-container .ui-icon-pencil,.control-section-redux .ui-icon-pencil,.control-panel-redux .ui-icon-pencil,.redux-metabox .ui-icon-pencil{background-position:-64px -112px}.redux-container .ui-icon-clock,.control-section-redux .ui-icon-clock,.control-panel-redux .ui-icon-clock,.redux-metabox .ui-icon-clock{background-position:-80px -112px}.redux-container .ui-icon-disk,.control-section-redux .ui-icon-disk,.control-panel-redux .ui-icon-disk,.redux-metabox .ui-icon-disk{background-position:-96px -112px}.redux-container .ui-icon-calculator,.control-section-redux .ui-icon-calculator,.control-panel-redux .ui-icon-calculator,.redux-metabox .ui-icon-calculator{background-position:-112px -112px}.redux-container .ui-icon-zoomin,.control-section-redux .ui-icon-zoomin,.control-panel-redux .ui-icon-zoomin,.redux-metabox .ui-icon-zoomin{background-position:-128px -112px}.redux-container .ui-icon-zoomout,.control-section-redux .ui-icon-zoomout,.control-panel-redux .ui-icon-zoomout,.redux-metabox .ui-icon-zoomout{background-position:-144px -112px}.redux-container .ui-icon-search,.control-section-redux .ui-icon-search,.control-panel-redux .ui-icon-search,.redux-metabox .ui-icon-search{background-position:-160px -112px}.redux-container .ui-icon-wrench,.control-section-redux .ui-icon-wrench,.control-panel-redux .ui-icon-wrench,.redux-metabox .ui-icon-wrench{background-position:-176px -112px}.redux-container .ui-icon-gear,.control-section-redux .ui-icon-gear,.control-panel-redux .ui-icon-gear,.redux-metabox .ui-icon-gear{background-position:-192px -112px}.redux-container .ui-icon-heart,.control-section-redux .ui-icon-heart,.control-panel-redux .ui-icon-heart,.redux-metabox .ui-icon-heart{background-position:-208px -112px}.redux-container .ui-icon-star,.control-section-redux .ui-icon-star,.control-panel-redux .ui-icon-star,.redux-metabox .ui-icon-star{background-position:-224px -112px}.redux-container .ui-icon-link,.control-section-redux .ui-icon-link,.control-panel-redux .ui-icon-link,.redux-metabox .ui-icon-link{background-position:-240px -112px}.redux-container .ui-icon-cancel,.control-section-redux .ui-icon-cancel,.control-panel-redux .ui-icon-cancel,.redux-metabox .ui-icon-cancel{background-position:0 -128px}.redux-container .ui-icon-plus,.control-section-redux .ui-icon-plus,.control-panel-redux .ui-icon-plus,.redux-metabox .ui-icon-plus{background-position:-16px -128px}.redux-container .ui-icon-plusthick,.control-section-redux .ui-icon-plusthick,.control-panel-redux .ui-icon-plusthick,.redux-metabox .ui-icon-plusthick{background-position:-32px -128px}.redux-container .ui-icon-minus,.control-section-redux .ui-icon-minus,.control-panel-redux .ui-icon-minus,.redux-metabox .ui-icon-minus{background-position:-48px -128px}.redux-container .ui-icon-minusthick,.control-section-redux .ui-icon-minusthick,.control-panel-redux .ui-icon-minusthick,.redux-metabox .ui-icon-minusthick{background-position:-64px -128px}.redux-container .ui-icon-close,.control-section-redux .ui-icon-close,.control-panel-redux .ui-icon-close,.redux-metabox .ui-icon-close{background-position:-80px -128px}.redux-container .ui-icon-closethick,.control-section-redux .ui-icon-closethick,.control-panel-redux .ui-icon-closethick,.redux-metabox .ui-icon-closethick{background-position:-96px -128px}.redux-container .ui-icon-key,.control-section-redux .ui-icon-key,.control-panel-redux .ui-icon-key,.redux-metabox .ui-icon-key{background-position:-112px -128px}.redux-container .ui-icon-lightbulb,.control-section-redux .ui-icon-lightbulb,.control-panel-redux .ui-icon-lightbulb,.redux-metabox .ui-icon-lightbulb{background-position:-128px -128px}.redux-container .ui-icon-scissors,.control-section-redux .ui-icon-scissors,.control-panel-redux .ui-icon-scissors,.redux-metabox .ui-icon-scissors{background-position:-144px -128px}.redux-container .ui-icon-clipboard,.control-section-redux .ui-icon-clipboard,.control-panel-redux .ui-icon-clipboard,.redux-metabox .ui-icon-clipboard{background-position:-160px -128px}.redux-container .ui-icon-copy,.control-section-redux .ui-icon-copy,.control-panel-redux .ui-icon-copy,.redux-metabox .ui-icon-copy{background-position:-176px -128px}.redux-container .ui-icon-contact,.control-section-redux .ui-icon-contact,.control-panel-redux .ui-icon-contact,.redux-metabox .ui-icon-contact{background-position:-192px -128px}.redux-container .ui-icon-image,.control-section-redux .ui-icon-image,.control-panel-redux .ui-icon-image,.redux-metabox .ui-icon-image{background-position:-208px -128px}.redux-container .ui-icon-video,.control-section-redux .ui-icon-video,.control-panel-redux .ui-icon-video,.redux-metabox .ui-icon-video{background-position:-224px -128px}.redux-container .ui-icon-script,.control-section-redux .ui-icon-script,.control-panel-redux .ui-icon-script,.redux-metabox .ui-icon-script{background-position:-240px -128px}.redux-container .ui-icon-alert,.control-section-redux .ui-icon-alert,.control-panel-redux .ui-icon-alert,.redux-metabox .ui-icon-alert{background-position:0 -144px}.redux-container .ui-icon-info,.control-section-redux .ui-icon-info,.control-panel-redux .ui-icon-info,.redux-metabox .ui-icon-info{background-position:-16px -144px}.redux-container .ui-icon-notice,.control-section-redux .ui-icon-notice,.control-panel-redux .ui-icon-notice,.redux-metabox .ui-icon-notice{background-position:-32px -144px}.redux-container .ui-icon-help,.control-section-redux .ui-icon-help,.control-panel-redux .ui-icon-help,.redux-metabox .ui-icon-help{background-position:-48px -144px}.redux-container .ui-icon-check,.control-section-redux .ui-icon-check,.control-panel-redux .ui-icon-check,.redux-metabox .ui-icon-check{background-position:-64px -144px}.redux-container .ui-icon-bullet,.control-section-redux .ui-icon-bullet,.control-panel-redux .ui-icon-bullet,.redux-metabox .ui-icon-bullet{background-position:-80px -144px}.redux-container .ui-icon-radio-off,.control-section-redux .ui-icon-radio-off,.control-panel-redux .ui-icon-radio-off,.redux-metabox .ui-icon-radio-off{background-position:-96px -144px}.redux-container .ui-icon-radio-on,.control-section-redux .ui-icon-radio-on,.control-panel-redux .ui-icon-radio-on,.redux-metabox .ui-icon-radio-on{background-position:-112px -144px}.redux-container .ui-icon-pin-w,.control-section-redux .ui-icon-pin-w,.control-panel-redux .ui-icon-pin-w,.redux-metabox .ui-icon-pin-w{background-position:-128px -144px}.redux-container .ui-icon-pin-s,.control-section-redux .ui-icon-pin-s,.control-panel-redux .ui-icon-pin-s,.redux-metabox .ui-icon-pin-s{background-position:-144px -144px}.redux-container .ui-icon-play,.control-section-redux .ui-icon-play,.control-panel-redux .ui-icon-play,.redux-metabox .ui-icon-play{background-position:0 -160px}.redux-container .ui-icon-pause,.control-section-redux .ui-icon-pause,.control-panel-redux .ui-icon-pause,.redux-metabox .ui-icon-pause{background-position:-16px -160px}.redux-container .ui-icon-seek-next,.control-section-redux .ui-icon-seek-next,.control-panel-redux .ui-icon-seek-next,.redux-metabox .ui-icon-seek-next{background-position:-32px -160px}.redux-container .ui-icon-seek-prev,.control-section-redux .ui-icon-seek-prev,.control-panel-redux .ui-icon-seek-prev,.redux-metabox .ui-icon-seek-prev{background-position:-48px -160px}.redux-container .ui-icon-seek-end,.control-section-redux .ui-icon-seek-end,.control-panel-redux .ui-icon-seek-end,.redux-metabox .ui-icon-seek-end{background-position:-64px -160px}.redux-container .ui-icon-seek-start,.control-section-redux .ui-icon-seek-start,.control-panel-redux .ui-icon-seek-start,.redux-metabox .ui-icon-seek-start{background-position:-80px -160px}.redux-container .ui-icon-seek-first,.control-section-redux .ui-icon-seek-first,.control-panel-redux .ui-icon-seek-first,.redux-metabox .ui-icon-seek-first{background-position:-80px -160px}.redux-container .ui-icon-stop,.control-section-redux .ui-icon-stop,.control-panel-redux .ui-icon-stop,.redux-metabox .ui-icon-stop{background-position:-96px -160px}.redux-container .ui-icon-eject,.control-section-redux .ui-icon-eject,.control-panel-redux .ui-icon-eject,.redux-metabox .ui-icon-eject{background-position:-112px -160px}.redux-container .ui-icon-volume-off,.control-section-redux .ui-icon-volume-off,.control-panel-redux .ui-icon-volume-off,.redux-metabox .ui-icon-volume-off{background-position:-128px -160px}.redux-container .ui-icon-volume-on,.control-section-redux .ui-icon-volume-on,.control-panel-redux .ui-icon-volume-on,.redux-metabox .ui-icon-volume-on{background-position:-144px -160px}.redux-container .ui-icon-power,.control-section-redux .ui-icon-power,.control-panel-redux .ui-icon-power,.redux-metabox .ui-icon-power{background-position:0 -176px}.redux-container .ui-icon-signal-diag,.control-section-redux .ui-icon-signal-diag,.control-panel-redux .ui-icon-signal-diag,.redux-metabox .ui-icon-signal-diag{background-position:-16px -176px}.redux-container .ui-icon-signal,.control-section-redux .ui-icon-signal,.control-panel-redux .ui-icon-signal,.redux-metabox .ui-icon-signal{background-position:-32px -176px}.redux-container .ui-icon-battery-0,.control-section-redux .ui-icon-battery-0,.control-panel-redux .ui-icon-battery-0,.redux-metabox .ui-icon-battery-0{background-position:-48px -176px}.redux-container .ui-icon-battery-1,.control-section-redux .ui-icon-battery-1,.control-panel-redux .ui-icon-battery-1,.redux-metabox .ui-icon-battery-1{background-position:-64px -176px}.redux-container .ui-icon-battery-2,.control-section-redux .ui-icon-battery-2,.control-panel-redux .ui-icon-battery-2,.redux-metabox .ui-icon-battery-2{background-position:-80px -176px}.redux-container .ui-icon-battery-3,.control-section-redux .ui-icon-battery-3,.control-panel-redux .ui-icon-battery-3,.redux-metabox .ui-icon-battery-3{background-position:-96px -176px}.redux-container .ui-icon-circle-plus,.control-section-redux .ui-icon-circle-plus,.control-panel-redux .ui-icon-circle-plus,.redux-metabox .ui-icon-circle-plus{background-position:0 -192px}.redux-container .ui-icon-circle-minus,.control-section-redux .ui-icon-circle-minus,.control-panel-redux .ui-icon-circle-minus,.redux-metabox .ui-icon-circle-minus{background-position:-16px -192px}.redux-container .ui-icon-circle-close,.control-section-redux .ui-icon-circle-close,.control-panel-redux .ui-icon-circle-close,.redux-metabox .ui-icon-circle-close{background-position:-32px -192px}.redux-container .ui-icon-circle-triangle-e,.control-section-redux .ui-icon-circle-triangle-e,.control-panel-redux .ui-icon-circle-triangle-e,.redux-metabox .ui-icon-circle-triangle-e{background-position:-48px -192px}.redux-container .ui-icon-circle-triangle-s,.control-section-redux .ui-icon-circle-triangle-s,.control-panel-redux .ui-icon-circle-triangle-s,.redux-metabox .ui-icon-circle-triangle-s{background-position:-64px -192px}.redux-container .ui-icon-circle-triangle-w,.control-section-redux .ui-icon-circle-triangle-w,.control-panel-redux .ui-icon-circle-triangle-w,.redux-metabox .ui-icon-circle-triangle-w{background-position:-80px -192px}.redux-container .ui-icon-circle-triangle-n,.control-section-redux .ui-icon-circle-triangle-n,.control-panel-redux .ui-icon-circle-triangle-n,.redux-metabox .ui-icon-circle-triangle-n{background-position:-96px -192px}.redux-container .ui-icon-circle-arrow-e,.control-section-redux .ui-icon-circle-arrow-e,.control-panel-redux .ui-icon-circle-arrow-e,.redux-metabox .ui-icon-circle-arrow-e{background-position:-112px -192px}.redux-container .ui-icon-circle-arrow-s,.control-section-redux .ui-icon-circle-arrow-s,.control-panel-redux .ui-icon-circle-arrow-s,.redux-metabox .ui-icon-circle-arrow-s{background-position:-128px -192px}.redux-container .ui-icon-circle-arrow-w,.control-section-redux .ui-icon-circle-arrow-w,.control-panel-redux .ui-icon-circle-arrow-w,.redux-metabox .ui-icon-circle-arrow-w{background-position:-144px -192px}.redux-container .ui-icon-circle-arrow-n,.control-section-redux .ui-icon-circle-arrow-n,.control-panel-redux .ui-icon-circle-arrow-n,.redux-metabox .ui-icon-circle-arrow-n{background-position:-160px -192px}.redux-container .ui-icon-circle-zoomin,.control-section-redux .ui-icon-circle-zoomin,.control-panel-redux .ui-icon-circle-zoomin,.redux-metabox .ui-icon-circle-zoomin{background-position:-176px -192px}.redux-container .ui-icon-circle-zoomout,.control-section-redux .ui-icon-circle-zoomout,.control-panel-redux .ui-icon-circle-zoomout,.redux-metabox .ui-icon-circle-zoomout{background-position:-192px -192px}.redux-container .ui-icon-circle-check,.control-section-redux .ui-icon-circle-check,.control-panel-redux .ui-icon-circle-check,.redux-metabox .ui-icon-circle-check{background-position:-208px -192px}.redux-container .ui-icon-circlesmall-plus,.control-section-redux .ui-icon-circlesmall-plus,.control-panel-redux .ui-icon-circlesmall-plus,.redux-metabox .ui-icon-circlesmall-plus{background-position:0 -208px}.redux-container .ui-icon-circlesmall-minus,.control-section-redux .ui-icon-circlesmall-minus,.control-panel-redux .ui-icon-circlesmall-minus,.redux-metabox .ui-icon-circlesmall-minus{background-position:-16px -208px}.redux-container .ui-icon-circlesmall-close,.control-section-redux .ui-icon-circlesmall-close,.control-panel-redux .ui-icon-circlesmall-close,.redux-metabox .ui-icon-circlesmall-close{background-position:-32px -208px}.redux-container .ui-icon-squaresmall-plus,.control-section-redux .ui-icon-squaresmall-plus,.control-panel-redux .ui-icon-squaresmall-plus,.redux-metabox .ui-icon-squaresmall-plus{background-position:-48px -208px}.redux-container .ui-icon-squaresmall-minus,.control-section-redux .ui-icon-squaresmall-minus,.control-panel-redux .ui-icon-squaresmall-minus,.redux-metabox .ui-icon-squaresmall-minus{background-position:-64px -208px}.redux-container .ui-icon-squaresmall-close,.control-section-redux .ui-icon-squaresmall-close,.control-panel-redux .ui-icon-squaresmall-close,.redux-metabox .ui-icon-squaresmall-close{background-position:-80px -208px}.redux-container .ui-icon-grip-dotted-vertical,.control-section-redux .ui-icon-grip-dotted-vertical,.control-panel-redux .ui-icon-grip-dotted-vertical,.redux-metabox .ui-icon-grip-dotted-vertical{background-position:0 -224px}.redux-container .ui-icon-grip-dotted-horizontal,.control-section-redux .ui-icon-grip-dotted-horizontal,.control-panel-redux .ui-icon-grip-dotted-horizontal,.redux-metabox .ui-icon-grip-dotted-horizontal{background-position:-16px -224px}.redux-container .ui-icon-grip-solid-vertical,.control-section-redux .ui-icon-grip-solid-vertical,.control-panel-redux .ui-icon-grip-solid-vertical,.redux-metabox .ui-icon-grip-solid-vertical{background-position:-32px -224px}.redux-container .ui-icon-grip-solid-horizontal,.control-section-redux .ui-icon-grip-solid-horizontal,.control-panel-redux .ui-icon-grip-solid-horizontal,.redux-metabox .ui-icon-grip-solid-horizontal{background-position:-48px -224px}.redux-container .ui-icon-gripsmall-diagonal-se,.control-section-redux .ui-icon-gripsmall-diagonal-se,.control-panel-redux .ui-icon-gripsmall-diagonal-se,.redux-metabox .ui-icon-gripsmall-diagonal-se{background-position:-64px -224px}.redux-container .ui-icon-grip-diagonal-se,.control-section-redux .ui-icon-grip-diagonal-se,.control-panel-redux .ui-icon-grip-diagonal-se,.redux-metabox .ui-icon-grip-diagonal-se{background-position:-80px -224px}.redux-container .ui-corner-all,.redux-container .ui-corner-top,.redux-container .ui-corner-left,.redux-container .ui-corner-tl,.control-section-redux .ui-corner-all,.control-section-redux .ui-corner-top,.control-section-redux .ui-corner-left,.control-section-redux .ui-corner-tl,.control-panel-redux .ui-corner-all,.control-panel-redux .ui-corner-top,.control-panel-redux .ui-corner-left,.control-panel-redux .ui-corner-tl,.redux-metabox .ui-corner-all,.redux-metabox .ui-corner-top,.redux-metabox .ui-corner-left,.redux-metabox .ui-corner-tl{-moz-border-radius-topleft:4px;-webkit-border-top-left-radius:4px;-khtml-border-top-left-radius:4px;border-top-left-radius:4px}.redux-container .ui-corner-all,.redux-container .ui-corner-top,.redux-container .ui-corner-right,.redux-container .ui-corner-tr,.control-section-redux .ui-corner-all,.control-section-redux .ui-corner-top,.control-section-redux .ui-corner-right,.control-section-redux .ui-corner-tr,.control-panel-redux .ui-corner-all,.control-panel-redux .ui-corner-top,.control-panel-redux .ui-corner-right,.control-panel-redux .ui-corner-tr,.redux-metabox .ui-corner-all,.redux-metabox .ui-corner-top,.redux-metabox .ui-corner-right,.redux-metabox .ui-corner-tr{-moz-border-radius-topright:4px;-webkit-border-top-right-radius:4px;-khtml-border-top-right-radius:4px;border-top-right-radius:4px}.redux-container .ui-corner-all,.redux-container .ui-corner-bottom,.redux-container .ui-corner-left,.redux-container .ui-corner-bl,.control-section-redux .ui-corner-all,.control-section-redux .ui-corner-bottom,.control-section-redux .ui-corner-left,.control-section-redux .ui-corner-bl,.control-panel-redux .ui-corner-all,.control-panel-redux .ui-corner-bottom,.control-panel-redux .ui-corner-left,.control-panel-redux .ui-corner-bl,.redux-metabox .ui-corner-all,.redux-metabox .ui-corner-bottom,.redux-metabox .ui-corner-left,.redux-metabox .ui-corner-bl{-moz-border-radius-bottomleft:4px;-webkit-border-bottom-left-radius:4px;-khtml-border-bottom-left-radius:4px;border-bottom-left-radius:4px}.redux-container .ui-corner-all,.redux-container .ui-corner-bottom,.redux-container .ui-corner-right,.redux-container .ui-corner-br,.control-section-redux .ui-corner-all,.control-section-redux .ui-corner-bottom,.control-section-redux .ui-corner-right,.control-section-redux .ui-corner-br,.control-panel-redux .ui-corner-all,.control-panel-redux .ui-corner-bottom,.control-panel-redux .ui-corner-right,.control-panel-redux .ui-corner-br,.redux-metabox .ui-corner-all,.redux-metabox .ui-corner-bottom,.redux-metabox .ui-corner-right,.redux-metabox .ui-corner-br{-moz-border-radius-bottomright:4px;-webkit-border-bottom-right-radius:4px;-khtml-border-bottom-right-radius:4px;border-bottom-right-radius:4px}.redux-container .ui-widget-overlay,.control-section-redux .ui-widget-overlay,.control-panel-redux .ui-widget-overlay,.redux-metabox .ui-widget-overlay{background:#aaa url(images/ui-bg_flat_0_aaaaaa_40x100.png) 50% 50% repeat-x;opacity:.30;filter:Alpha(Opacity=30)}.redux-container .ui-widget-shadow,.control-section-redux .ui-widget-shadow,.control-panel-redux .ui-widget-shadow,.redux-metabox .ui-widget-shadow{margin:-8px 0 0 -8px;padding:8px;background:#aaa url(images/ui-bg_flat_0_aaaaaa_40x100.png) 50% 50% repeat-x;opacity:.30;filter:Alpha(Opacity=30);-moz-border-radius:8px;-khtml-border-radius:8px;-webkit-border-radius:8px;border-radius:8px}.redux-container .ui-accordion,.control-section-redux .ui-accordion,.control-panel-redux .ui-accordion,.redux-metabox .ui-accordion{width:100%}.redux-container .ui-accordion .ui-accordion-header,.control-section-redux .ui-accordion .ui-accordion-header,.control-panel-redux .ui-accordion .ui-accordion-header,.redux-metabox .ui-accordion .ui-accordion-header{cursor:pointer;position:relative;margin-top:1px;zoom:1;font-weight:bold}.redux-container .ui-accordion .ui-accordion-li-fix,.control-section-redux .ui-accordion .ui-accordion-li-fix,.control-panel-redux .ui-accordion .ui-accordion-li-fix,.redux-metabox .ui-accordion .ui-accordion-li-fix{display:inline}.redux-container .ui-accordion .ui-accordion-header-active,.control-section-redux .ui-accordion .ui-accordion-header-active,.control-panel-redux .ui-accordion .ui-accordion-header-active,.redux-metabox .ui-accordion .ui-accordion-header-active{border-bottom:0 !important}.redux-container .ui-accordion .ui-accordion-header a,.control-section-redux .ui-accordion .ui-accordion-header a,.control-panel-redux .ui-accordion .ui-accordion-header a,.redux-metabox .ui-accordion .ui-accordion-header a{display:block;font-size:1em;padding:.5em .5em .5em 1.7em}.redux-container .ui-accordion-icons .ui-accordion-header a,.control-section-redux .ui-accordion-icons .ui-accordion-header a,.control-panel-redux .ui-accordion-icons .ui-accordion-header a,.redux-metabox .ui-accordion-icons .ui-accordion-header a{padding-left:2.2em}.redux-container .ui-accordion .ui-accordion-header .ui-icon,.control-section-redux .ui-accordion .ui-accordion-header .ui-icon,.control-panel-redux .ui-accordion .ui-accordion-header .ui-icon,.redux-metabox .ui-accordion .ui-accordion-header .ui-icon{position:absolute;left:.5em;top:50%;margin-top:-8px}.redux-container .ui-accordion .ui-accordion-content,.control-section-redux .ui-accordion .ui-accordion-content,.control-panel-redux .ui-accordion .ui-accordion-content,.redux-metabox .ui-accordion .ui-accordion-content{padding:1em 2.2em;border-top:0;margin-top:-2px;position:relative;top:1px;margin-bottom:2px;overflow:auto;display:none;zoom:1}.redux-container .ui-accordion .ui-accordion-content-active,.control-section-redux .ui-accordion .ui-accordion-content-active,.control-panel-redux .ui-accordion .ui-accordion-content-active,.redux-metabox .ui-accordion .ui-accordion-content-active{display:block}.redux-container .ui-button,.control-section-redux .ui-button,.control-panel-redux .ui-button,.redux-metabox .ui-button{cursor:pointer;display:inline-block;background-color:#e6e6e6;background-repeat:no-repeat;background-image:-webkit-gradient(linear, 0 0, 0 100%, from(#fff), color-stop(25%, #fff), to(#e6e6e6));background-image:-webkit-linear-gradient(#fff, #fff 25%, #e6e6e6);background-image:-moz-linear-gradient(top, #fff, #fff 25%, #e6e6e6);background-image:-ms-linear-gradient(#fff, #fff 25%, #e6e6e6);background-image:-o-linear-gradient(#fff, #fff 25%, #e6e6e6);background-image:linear-gradient(#fff, #fff 25%, #e6e6e6);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffffff', endColorstr='#e6e6e6', GradientType=0);padding:5px 14px 6px;margin:0;text-shadow:0 1px 1px rgba(255,255,255,0.75);color:#333;font-size:13px;line-height:normal;border:1px solid #ccc;border-bottom-color:#bbb;-webkit-box-shadow:inset 0 1px 0 rgba(255,255,255,0.2),0 1px 2px rgba(0,0,0,0.05);-moz-box-shadow:inset 0 1px 0 rgba(255,255,255,0.2),0 1px 2px rgba(0,0,0,0.05);box-shadow:inset 0 1px 0 rgba(255,255,255,0.2),0 1px 2px rgba(0,0,0,0.05);-webkit-transition:0.1s linear background-image;-moz-transition:0.1s linear background-image;-ms-transition:0.1s linear background-image;-o-transition:0.1s linear background-image;transition:0.1s linear background-image;overflow:visible}.redux-container .ui-button-primary,.control-section-redux .ui-button-primary,.control-panel-redux .ui-button-primary,.redux-metabox .ui-button-primary{color:#ffffff;background-color:#0064cd;background-repeat:repeat-x;background-image:-khtml-gradient(linear, left top, left bottom, from(#049cdb), to(#0064cd));background-image:-moz-linear-gradient(top, #049cdb, #0064cd);background-image:-ms-linear-gradient(top, #049cdb, #0064cd);background-image:-webkit-gradient(linear, left top, left bottom, color-stop(0%, #049cdb), color-stop(100%, #0064cd));background-image:-webkit-linear-gradient(top, #049cdb, #0064cd);background-image:-o-linear-gradient(top, #049cdb, #0064cd);background-image:linear-gradient(top, #049cdb, #0064cd);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#049cdb', endColorstr='#0064cd', GradientType=0);text-shadow:0 -1px 0 rgba(0,0,0,0.25);border-color:#0064cd #0064cd #003f81;border-color:rgba(0,0,0,0.1) rgba(0,0,0,0.1) rgba(0,0,0,0.25)}.redux-container .ui-button-success,.control-section-redux .ui-button-success,.control-panel-redux .ui-button-success,.redux-metabox .ui-button-success{color:#ffffff;background-color:#57a957;background-repeat:repeat-x;background-image:-khtml-gradient(linear, left top, left bottom, from(#62c462), to(#57a957));background-image:-moz-linear-gradient(top, #62c462, #57a957);background-image:-ms-linear-gradient(top, #62c462, #57a957);background-image:-webkit-gradient(linear, left top, left bottom, color-stop(0%, #62c462), color-stop(100%, #57a957));background-image:-webkit-linear-gradient(top, #62c462, #57a957);background-image:-o-linear-gradient(top, #62c462, #57a957);background-image:linear-gradient(top, #62c462, #57a957);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#62c462', endColorstr='#57a957', GradientType=0);text-shadow:0 -1px 0 rgba(0,0,0,0.25);border-color:#57a957 #57a957 #3d773d;border-color:rgba(0,0,0,0.1) rgba(0,0,0,0.1) rgba(0,0,0,0.25)}.redux-container .ui-button-error,.control-section-redux .ui-button-error,.control-panel-redux .ui-button-error,.redux-metabox .ui-button-error{color:#ffffff;background-color:#c43c35;background-repeat:repeat-x;background-image:-khtml-gradient(linear, left top, left bottom, from(#ee5f5b), to(#c43c35));background-image:-moz-linear-gradient(top, #ee5f5b, #c43c35);background-image:-ms-linear-gradient(top, #ee5f5b, #c43c35);background-image:-webkit-gradient(linear, left top, left bottom, color-stop(0%, #ee5f5b), color-stop(100%, #c43c35));background-image:-webkit-linear-gradient(top, #ee5f5b, #c43c35);background-image:-o-linear-gradient(top, #ee5f5b, #c43c35);background-image:linear-gradient(top, #ee5f5b, #c43c35);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#ee5f5b', endColorstr='#c43c35', GradientType=0);text-shadow:0 -1px 0 rgba(0,0,0,0.25);border-color:#c43c35 #c43c35 #882a25;border-color:rgba(0,0,0,0.1) rgba(0,0,0,0.1) rgba(0,0,0,0.25)}.redux-container .ui-button-icon-only,.control-section-redux .ui-button-icon-only,.control-panel-redux .ui-button-icon-only,.redux-metabox .ui-button-icon-only{width:2.2em}.redux-container .ui-button-icons-only,.control-section-redux .ui-button-icons-only,.control-panel-redux .ui-button-icons-only,.redux-metabox .ui-button-icons-only{width:3.4em}.redux-container button.ui-button-icons-only,.control-section-redux button.ui-button-icons-only,.control-panel-redux button.ui-button-icons-only,.redux-metabox button.ui-button-icons-only{width:3.7em}.redux-container .ui-button .ui-button-text,.control-section-redux .ui-button .ui-button-text,.control-panel-redux .ui-button .ui-button-text,.redux-metabox .ui-button .ui-button-text{display:block}.redux-container .ui-button-icon-only .ui-button-text,.redux-container .ui-button-icons-only .ui-button-text,.control-section-redux .ui-button-icon-only .ui-button-text,.control-section-redux .ui-button-icons-only .ui-button-text,.control-panel-redux .ui-button-icon-only .ui-button-text,.control-panel-redux .ui-button-icons-only .ui-button-text,.redux-metabox .ui-button-icon-only .ui-button-text,.redux-metabox .ui-button-icons-only .ui-button-text{padding:.4em;text-indent:-9999999px;display:none}.redux-container .ui-button-text-icon-primary .ui-button-text,.redux-container .ui-button-text-icons .ui-button-text,.control-section-redux .ui-button-text-icon-primary .ui-button-text,.control-section-redux .ui-button-text-icons .ui-button-text,.control-panel-redux .ui-button-text-icon-primary .ui-button-text,.control-panel-redux .ui-button-text-icons .ui-button-text,.redux-metabox .ui-button-text-icon-primary .ui-button-text,.redux-metabox .ui-button-text-icons .ui-button-text{padding:.4em 1em .4em 2.1em}.redux-container .ui-button-text-icon-secondary .ui-button-text,.redux-container .ui-button-text-icons .ui-button-text,.control-section-redux .ui-button-text-icon-secondary .ui-button-text,.control-section-redux .ui-button-text-icons .ui-button-text,.control-panel-redux .ui-button-text-icon-secondary .ui-button-text,.control-panel-redux .ui-button-text-icons .ui-button-text,.redux-metabox .ui-button-text-icon-secondary .ui-button-text,.redux-metabox .ui-button-text-icons .ui-button-text{padding:.4em 2.1em .4em 1em}.redux-container .ui-button-text-icons .ui-button-text,.control-section-redux .ui-button-text-icons .ui-button-text,.control-panel-redux .ui-button-text-icons .ui-button-text,.redux-metabox .ui-button-text-icons .ui-button-text{padding-left:2.1em;padding-right:2.1em}.redux-container .ui-button-icon-only .ui-icon,.redux-container .ui-button-text-icon-primary .ui-icon,.redux-container .ui-button-text-icon-secondary .ui-icon,.redux-container .ui-button-text-icons .ui-icon,.redux-container .ui-button-icons-only .ui-icon,.control-section-redux .ui-button-icon-only .ui-icon,.control-section-redux .ui-button-text-icon-primary .ui-icon,.control-section-redux .ui-button-text-icon-secondary .ui-icon,.control-section-redux .ui-button-text-icons .ui-icon,.control-section-redux .ui-button-icons-only .ui-icon,.control-panel-redux .ui-button-icon-only .ui-icon,.control-panel-redux .ui-button-text-icon-primary .ui-icon,.control-panel-redux .ui-button-text-icon-secondary .ui-icon,.control-panel-redux .ui-button-text-icons .ui-icon,.control-panel-redux .ui-button-icons-only .ui-icon,.redux-metabox .ui-button-icon-only .ui-icon,.redux-metabox .ui-button-text-icon-primary .ui-icon,.redux-metabox .ui-button-text-icon-secondary .ui-icon,.redux-metabox .ui-button-text-icons .ui-icon,.redux-metabox .ui-button-icons-only .ui-icon{top:50%;margin-top:-3px;margin-bottom:3px}.redux-container .ui-button-icon-only .ui-icon,.control-section-redux .ui-button-icon-only .ui-icon,.control-panel-redux .ui-button-icon-only .ui-icon,.redux-metabox .ui-button-icon-only .ui-icon{left:50%;margin-left:-8px}.redux-container .ui-button-text-icon-primary .ui-button-icon-primary,.redux-container .ui-button-text-icons .ui-button-icon-primary,.redux-container .ui-button-icons-only .ui-button-icon-primary,.control-section-redux .ui-button-text-icon-primary .ui-button-icon-primary,.control-section-redux .ui-button-text-icons .ui-button-icon-primary,.control-section-redux .ui-button-icons-only .ui-button-icon-primary,.control-panel-redux .ui-button-text-icon-primary .ui-button-icon-primary,.control-panel-redux .ui-button-text-icons .ui-button-icon-primary,.control-panel-redux .ui-button-icons-only .ui-button-icon-primary,.redux-metabox .ui-button-text-icon-primary .ui-button-icon-primary,.redux-metabox .ui-button-text-icons .ui-button-icon-primary,.redux-metabox .ui-button-icons-only .ui-button-icon-primary{left:.5em}.redux-container .ui-button-text-icon-secondary .ui-button-icon-secondary,.redux-container .ui-button-text-icons .ui-button-icon-secondary,.redux-container .ui-button-icons-only .ui-button-icon-secondary,.control-section-redux .ui-button-text-icon-secondary .ui-button-icon-secondary,.control-section-redux .ui-button-text-icons .ui-button-icon-secondary,.control-section-redux .ui-button-icons-only .ui-button-icon-secondary,.control-panel-redux .ui-button-text-icon-secondary .ui-button-icon-secondary,.control-panel-redux .ui-button-text-icons .ui-button-icon-secondary,.control-panel-redux .ui-button-icons-only .ui-button-icon-secondary,.redux-metabox .ui-button-text-icon-secondary .ui-button-icon-secondary,.redux-metabox .ui-button-text-icons .ui-button-icon-secondary,.redux-metabox .ui-button-icons-only .ui-button-icon-secondary{right:.5em}.redux-container .ui-button-text-icons .ui-button-icon-secondary,.redux-container .ui-button-icons-only .ui-button-icon-secondary,.control-section-redux .ui-button-text-icons .ui-button-icon-secondary,.control-section-redux .ui-button-icons-only .ui-button-icon-secondary,.control-panel-redux .ui-button-text-icons .ui-button-icon-secondary,.control-panel-redux .ui-button-icons-only .ui-button-icon-secondary,.redux-metabox .ui-button-text-icons .ui-button-icon-secondary,.redux-metabox .ui-button-icons-only .ui-button-icon-secondary{right:.5em}.redux-container .ui-buttonset,.control-section-redux .ui-buttonset,.control-panel-redux .ui-buttonset,.redux-metabox .ui-buttonset{margin-right:7px}.redux-container .ui-buttonset .ui-state-active,.control-section-redux .ui-buttonset .ui-state-active,.control-panel-redux .ui-buttonset .ui-state-active,.redux-metabox .ui-buttonset .ui-state-active{color:#ffffff;background-color:#0064cd;background-repeat:repeat-x;background-image:-khtml-gradient(linear, left top, left bottom, from(#049cdb), to(#0064cd));background-image:-moz-linear-gradient(top, #049cdb, #0064cd);background-image:-ms-linear-gradient(top, #049cdb, #0064cd);background-image:-webkit-gradient(linear, left top, left bottom, color-stop(0%, #049cdb), color-stop(100%, #0064cd));background-image:-webkit-linear-gradient(top, #049cdb, #0064cd);background-image:-o-linear-gradient(top, #049cdb, #0064cd);background-image:linear-gradient(top, #049cdb, #0064cd);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#049cdb', endColorstr='#0064cd', GradientType=0);text-shadow:0 -1px 0 rgba(0,0,0,0.25);border-color:#0064cd #0064cd #003f81;border-color:rgba(0,0,0,0.1) rgba(0,0,0,0.1) rgba(0,0,0,0.25)}.redux-container .ui-buttonset .ui-button,.control-section-redux .ui-buttonset .ui-button,.control-panel-redux .ui-buttonset .ui-button,.redux-metabox .ui-buttonset .ui-button{margin-left:0;margin-right:0}.redux-container button.ui-button::-moz-focus-inner,.control-section-redux button.ui-button::-moz-focus-inner,.control-panel-redux button.ui-button::-moz-focus-inner,.redux-metabox button.ui-button::-moz-focus-inner{border:0;padding:0}.redux-container .ui-datepicker,.control-section-redux .ui-datepicker,.control-panel-redux .ui-datepicker,.redux-metabox .ui-datepicker{width:17em;padding:.2em .2em 0;display:none}.redux-container .ui-datepicker .ui-datepicker-header,.control-section-redux .ui-datepicker .ui-datepicker-header,.control-panel-redux .ui-datepicker .ui-datepicker-header,.redux-metabox .ui-datepicker .ui-datepicker-header{position:relative;padding:.2em 0;border:0px;font-weight:bold;width:100%;padding:4px 0;background-color:#f5f5f5;color:#808080}.redux-container .ui-datepicker .ui-datepicker-prev,.redux-container .ui-datepicker .ui-datepicker-next,.control-section-redux .ui-datepicker .ui-datepicker-prev,.control-section-redux .ui-datepicker .ui-datepicker-next,.control-panel-redux .ui-datepicker .ui-datepicker-prev,.control-panel-redux .ui-datepicker .ui-datepicker-next,.redux-metabox .ui-datepicker .ui-datepicker-prev,.redux-metabox .ui-datepicker .ui-datepicker-next{position:absolute;top:2px;width:1.8em;height:1.8em}.redux-container .ui-datepicker .ui-datepicker-prev,.control-section-redux .ui-datepicker .ui-datepicker-prev,.control-panel-redux .ui-datepicker .ui-datepicker-prev,.redux-metabox .ui-datepicker .ui-datepicker-prev{left:2px}.redux-container .ui-datepicker .ui-datepicker-next,.control-section-redux .ui-datepicker .ui-datepicker-next,.control-panel-redux .ui-datepicker .ui-datepicker-next,.redux-metabox .ui-datepicker .ui-datepicker-next{right:2px}.redux-container .ui-datepicker .ui-datepicker-prev span,.redux-container .ui-datepicker .ui-datepicker-next span,.control-section-redux .ui-datepicker .ui-datepicker-prev span,.control-section-redux .ui-datepicker .ui-datepicker-next span,.control-panel-redux .ui-datepicker .ui-datepicker-prev span,.control-panel-redux .ui-datepicker .ui-datepicker-next span,.redux-metabox .ui-datepicker .ui-datepicker-prev span,.redux-metabox .ui-datepicker .ui-datepicker-next span{display:block;position:absolute;left:50%;margin-left:-8px;top:50%;margin-top:-8px}.redux-container .ui-datepicker .ui-datepicker-title,.control-section-redux .ui-datepicker .ui-datepicker-title,.control-panel-redux .ui-datepicker .ui-datepicker-title,.redux-metabox .ui-datepicker .ui-datepicker-title{margin:0 2.3em;line-height:1.8em;text-align:center}.redux-container .ui-datepicker .ui-datepicker-title select,.control-section-redux .ui-datepicker .ui-datepicker-title select,.control-panel-redux .ui-datepicker .ui-datepicker-title select,.redux-metabox .ui-datepicker .ui-datepicker-title select{font-size:1em;margin:1px 0}.redux-container .ui-datepicker select.ui-datepicker-month-year,.control-section-redux .ui-datepicker select.ui-datepicker-month-year,.control-panel-redux .ui-datepicker select.ui-datepicker-month-year,.redux-metabox .ui-datepicker select.ui-datepicker-month-year{width:100%}.redux-container .ui-datepicker select.ui-datepicker-month,.redux-container .ui-datepicker select.ui-datepicker-year,.control-section-redux .ui-datepicker select.ui-datepicker-month,.control-section-redux .ui-datepicker select.ui-datepicker-year,.control-panel-redux .ui-datepicker select.ui-datepicker-month,.control-panel-redux .ui-datepicker select.ui-datepicker-year,.redux-metabox .ui-datepicker select.ui-datepicker-month,.redux-metabox .ui-datepicker select.ui-datepicker-year{width:49%}.redux-container .ui-datepicker table,.control-section-redux .ui-datepicker table,.control-panel-redux .ui-datepicker table,.redux-metabox .ui-datepicker table{width:100%;font-size:.9em;border-collapse:collapse;margin:0 0 .4em}.redux-container .ui-datepicker th,.control-section-redux .ui-datepicker th,.control-panel-redux .ui-datepicker th,.redux-metabox .ui-datepicker th{padding:.7em .3em;text-align:center;font-weight:bold;border:0}.redux-container .ui-datepicker td,.control-section-redux .ui-datepicker td,.control-panel-redux .ui-datepicker td,.redux-metabox .ui-datepicker td{border:0;padding:1px}.redux-container .ui-datepicker td span,.redux-container .ui-datepicker td a,.control-section-redux .ui-datepicker td span,.control-section-redux .ui-datepicker td a,.control-panel-redux .ui-datepicker td span,.control-panel-redux .ui-datepicker td a,.redux-metabox .ui-datepicker td span,.redux-metabox .ui-datepicker td a{display:block;padding:.2em;text-align:right;text-decoration:none}.redux-container .ui-datepicker .ui-datepicker-buttonpane,.control-section-redux .ui-datepicker .ui-datepicker-buttonpane,.control-panel-redux .ui-datepicker .ui-datepicker-buttonpane,.redux-metabox .ui-datepicker .ui-datepicker-buttonpane{background-image:none;margin:.7em 0 0 0;padding:0 .2em;border-left:0;border-right:0;border-bottom:0}.redux-container .ui-datepicker .ui-datepicker-buttonpane button,.control-section-redux .ui-datepicker .ui-datepicker-buttonpane button,.control-panel-redux .ui-datepicker .ui-datepicker-buttonpane button,.redux-metabox .ui-datepicker .ui-datepicker-buttonpane button{float:right;margin:.5em .2em .4em;cursor:pointer;padding:.2em .6em .3em .6em;width:auto;overflow:visible}.redux-container .ui-datepicker .ui-datepicker-buttonpane button.ui-datepicker-current,.control-section-redux .ui-datepicker .ui-datepicker-buttonpane button.ui-datepicker-current,.control-panel-redux .ui-datepicker .ui-datepicker-buttonpane button.ui-datepicker-current,.redux-metabox .ui-datepicker .ui-datepicker-buttonpane button.ui-datepicker-current{float:left}.redux-container .ui-datepicker.ui-datepicker-multi,.control-section-redux .ui-datepicker.ui-datepicker-multi,.control-panel-redux .ui-datepicker.ui-datepicker-multi,.redux-metabox .ui-datepicker.ui-datepicker-multi{width:auto}.redux-container .ui-datepicker-multi .ui-datepicker-group,.control-section-redux .ui-datepicker-multi .ui-datepicker-group,.control-panel-redux .ui-datepicker-multi .ui-datepicker-group,.redux-metabox .ui-datepicker-multi .ui-datepicker-group{float:left}.redux-container .ui-datepicker-multi .ui-datepicker-group table,.control-section-redux .ui-datepicker-multi .ui-datepicker-group table,.control-panel-redux .ui-datepicker-multi .ui-datepicker-group table,.redux-metabox .ui-datepicker-multi .ui-datepicker-group table{width:95%;margin:0 auto .4em}.redux-container .ui-datepicker-multi-2 .ui-datepicker-group,.control-section-redux .ui-datepicker-multi-2 .ui-datepicker-group,.control-panel-redux .ui-datepicker-multi-2 .ui-datepicker-group,.redux-metabox .ui-datepicker-multi-2 .ui-datepicker-group{width:50%}.redux-container .ui-datepicker-multi-3 .ui-datepicker-group,.control-section-redux .ui-datepicker-multi-3 .ui-datepicker-group,.control-panel-redux .ui-datepicker-multi-3 .ui-datepicker-group,.redux-metabox .ui-datepicker-multi-3 .ui-datepicker-group{width:33.3%}.redux-container .ui-datepicker-multi-4 .ui-datepicker-group,.control-section-redux .ui-datepicker-multi-4 .ui-datepicker-group,.control-panel-redux .ui-datepicker-multi-4 .ui-datepicker-group,.redux-metabox .ui-datepicker-multi-4 .ui-datepicker-group{width:25%}.redux-container .ui-datepicker-multi .ui-datepicker-group-last .ui-datepicker-header,.control-section-redux .ui-datepicker-multi .ui-datepicker-group-last .ui-datepicker-header,.control-panel-redux .ui-datepicker-multi .ui-datepicker-group-last .ui-datepicker-header,.redux-metabox .ui-datepicker-multi .ui-datepicker-group-last .ui-datepicker-header{border-left-width:0}.redux-container .ui-datepicker-multi .ui-datepicker-group-middle .ui-datepicker-header,.control-section-redux .ui-datepicker-multi .ui-datepicker-group-middle .ui-datepicker-header,.control-panel-redux .ui-datepicker-multi .ui-datepicker-group-middle .ui-datepicker-header,.redux-metabox .ui-datepicker-multi .ui-datepicker-group-middle .ui-datepicker-header{border-left-width:0}.redux-container .ui-datepicker-multi .ui-datepicker-buttonpane,.control-section-redux .ui-datepicker-multi .ui-datepicker-buttonpane,.control-panel-redux .ui-datepicker-multi .ui-datepicker-buttonpane,.redux-metabox .ui-datepicker-multi .ui-datepicker-buttonpane{clear:left}.redux-container .ui-datepicker-row-break,.control-section-redux .ui-datepicker-row-break,.control-panel-redux .ui-datepicker-row-break,.redux-metabox .ui-datepicker-row-break{clear:both;width:100%;font-size:0em}.redux-container .ui-datepicker-rtl,.control-section-redux .ui-datepicker-rtl,.control-panel-redux .ui-datepicker-rtl,.redux-metabox .ui-datepicker-rtl{direction:rtl}.redux-container .ui-datepicker-rtl .ui-datepicker-prev,.control-section-redux .ui-datepicker-rtl .ui-datepicker-prev,.control-panel-redux .ui-datepicker-rtl .ui-datepicker-prev,.redux-metabox .ui-datepicker-rtl .ui-datepicker-prev{right:2px;left:auto}.redux-container .ui-datepicker-rtl .ui-datepicker-next,.control-section-redux .ui-datepicker-rtl .ui-datepicker-next,.control-panel-redux .ui-datepicker-rtl .ui-datepicker-next,.redux-metabox .ui-datepicker-rtl .ui-datepicker-next{left:2px;right:auto}.redux-container .ui-datepicker-rtl .ui-datepicker-prev:hover,.control-section-redux .ui-datepicker-rtl .ui-datepicker-prev:hover,.control-panel-redux .ui-datepicker-rtl .ui-datepicker-prev:hover,.redux-metabox .ui-datepicker-rtl .ui-datepicker-prev:hover{right:1px;left:auto}.redux-container .ui-datepicker-rtl .ui-datepicker-next:hover,.control-section-redux .ui-datepicker-rtl .ui-datepicker-next:hover,.control-panel-redux .ui-datepicker-rtl .ui-datepicker-next:hover,.redux-metabox .ui-datepicker-rtl .ui-datepicker-next:hover{left:1px;right:auto}.redux-container .ui-datepicker-rtl .ui-datepicker-buttonpane,.control-section-redux .ui-datepicker-rtl .ui-datepicker-buttonpane,.control-panel-redux .ui-datepicker-rtl .ui-datepicker-buttonpane,.redux-metabox .ui-datepicker-rtl .ui-datepicker-buttonpane{clear:right}.redux-container .ui-datepicker-rtl .ui-datepicker-buttonpane button,.control-section-redux .ui-datepicker-rtl .ui-datepicker-buttonpane button,.control-panel-redux .ui-datepicker-rtl .ui-datepicker-buttonpane button,.redux-metabox .ui-datepicker-rtl .ui-datepicker-buttonpane button{float:left}.redux-container .ui-datepicker-rtl .ui-datepicker-buttonpane button.ui-datepicker-current,.control-section-redux .ui-datepicker-rtl .ui-datepicker-buttonpane button.ui-datepicker-current,.control-panel-redux .ui-datepicker-rtl .ui-datepicker-buttonpane button.ui-datepicker-current,.redux-metabox .ui-datepicker-rtl .ui-datepicker-buttonpane button.ui-datepicker-current{float:right}.redux-container .ui-datepicker-rtl .ui-datepicker-group,.control-section-redux .ui-datepicker-rtl .ui-datepicker-group,.control-panel-redux .ui-datepicker-rtl .ui-datepicker-group,.redux-metabox .ui-datepicker-rtl .ui-datepicker-group{float:right}.redux-container .ui-datepicker-rtl .ui-datepicker-group-last .ui-datepicker-header,.control-section-redux .ui-datepicker-rtl .ui-datepicker-group-last .ui-datepicker-header,.control-panel-redux .ui-datepicker-rtl .ui-datepicker-group-last .ui-datepicker-header,.redux-metabox .ui-datepicker-rtl .ui-datepicker-group-last .ui-datepicker-header{border-right-width:0;border-left-width:1px}.redux-container .ui-datepicker-rtl .ui-datepicker-group-middle .ui-datepicker-header,.control-section-redux .ui-datepicker-rtl .ui-datepicker-group-middle .ui-datepicker-header,.control-panel-redux .ui-datepicker-rtl .ui-datepicker-group-middle .ui-datepicker-header,.redux-metabox .ui-datepicker-rtl .ui-datepicker-group-middle .ui-datepicker-header{border-right-width:0;border-left-width:1px}.redux-container .ui-datepicker-cover,.control-section-redux .ui-datepicker-cover,.control-panel-redux .ui-datepicker-cover,.redux-metabox .ui-datepicker-cover{display:none;display:block;position:absolute;z-index:-1;filter:mask();top:-4px;left:-4px;width:200px;height:200px}.redux-container .ui-datepicker th,.control-section-redux .ui-datepicker th,.control-panel-redux .ui-datepicker th,.redux-metabox .ui-datepicker th{font-weight:bold;color:gray}.redux-container .ui-datepicker-today a:hover,.control-section-redux .ui-datepicker-today a:hover,.control-panel-redux .ui-datepicker-today a:hover,.redux-metabox .ui-datepicker-today a:hover{background-color:#808080;color:#ffffff}.redux-container .ui-datepicker-today a,.control-section-redux .ui-datepicker-today a,.control-panel-redux .ui-datepicker-today a,.redux-metabox .ui-datepicker-today a{background-color:#BFBFBF;cursor:pointer;padding:0 4px;margin-bottom:0px}.redux-container .ui-datepicker td a,.control-section-redux .ui-datepicker td a,.control-panel-redux .ui-datepicker td a,.redux-metabox .ui-datepicker td a{margin-bottom:0px;border:0px}.redux-container .ui-datepicker td:hover,.control-section-redux .ui-datepicker td:hover,.control-panel-redux .ui-datepicker td:hover,.redux-metabox .ui-datepicker td:hover{color:#ffffff}.redux-container .ui-datepicker td .ui-state-default,.control-section-redux .ui-datepicker td .ui-state-default,.control-panel-redux .ui-datepicker td .ui-state-default,.redux-metabox .ui-datepicker td .ui-state-default{border:0px;background:none;margin-bottom:0px;padding:5px;color:gray;text-align:center;filter:none}.redux-container .ui-datepicker td .ui-state-active,.control-section-redux .ui-datepicker td .ui-state-active,.control-panel-redux .ui-datepicker td .ui-state-active,.redux-metabox .ui-datepicker td .ui-state-active{background:#BFBFBF;margin-bottom:0px;font-size:normal;text-shadow:0px;color:#ffffff;-webkit-border-radius:4px;-moz-border-radius:4px;border-radius:4px}.redux-container .ui-datepicker td .ui-state-hover,.control-section-redux .ui-datepicker td .ui-state-hover,.control-panel-redux .ui-datepicker td .ui-state-hover,.redux-metabox .ui-datepicker td .ui-state-hover{color:#ffffff;background:#0064cd;background-color:#0064cd;background-repeat:repeat-x;background-image:-khtml-gradient(linear, left top, left bottom, from(#049cdb), to(#0064cd));background-image:-moz-linear-gradient(top, #049cdb, #0064cd);background-image:-ms-linear-gradient(top, #049cdb, #0064cd);background-image:-webkit-gradient(linear, left top, left bottom, color-stop(0%, #049cdb), color-stop(100%, #0064cd));background-image:-webkit-linear-gradient(top, #049cdb, #0064cd);background-image:-o-linear-gradient(top, #049cdb, #0064cd);background-image:linear-gradient(top, #049cdb, #0064cd);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#049cdb', endColorstr='#0064cd', GradientType=0);text-shadow:0 -1px 0 rgba(0,0,0,0.25);border-color:#0064cd #0064cd #003f81;border-color:rgba(0,0,0,0.1) rgba(0,0,0,0.1) rgba(0,0,0,0.25);-webkit-border-radius:4px;-moz-border-radius:4px;-khtml-border-radius:4px;border-radius:4px}.redux-container .ui-widget-content,.control-section-redux .ui-widget-content,.control-panel-redux .ui-widget-content,.redux-metabox .ui-widget-content{border:1px solid #dfdfdf}.redux-container .ui-datepicker table,.control-section-redux .ui-datepicker table,.control-panel-redux .ui-datepicker table,.redux-metabox .ui-datepicker table{background:#fff}.redux-container .placeholder,.control-section-redux .placeholder,.control-panel-redux .placeholder,.redux-metabox .placeholder{background:#f9f9f9 !important;border:1px dashed #bbb !important}.wp-customizer #ui-datepicker-div{z-index:999999 !important} diff --git a/library/admin/ReduxCore/assets/css/vendor/jquery-ui-bootstrap/jquery-ui-1.10.0.custom.less b/library/admin/ReduxCore/assets/css/vendor/jquery-ui-bootstrap/jquery-ui-1.10.0.custom.less deleted file mode 100644 index c49bc414..00000000 --- a/library/admin/ReduxCore/assets/css/vendor/jquery-ui-bootstrap/jquery-ui-1.10.0.custom.less +++ /dev/null @@ -1,793 +0,0 @@ -/*! - * jQuery UI Bootstrap (0.5) - * http://addyosmani.github.com/jquery-ui-bootstrap - * - * Copyright 2012 - 2013, Addy Osmani - * Dual licensed under the MIT or GPL Version 2 licenses. - * - * Portions copyright jQuery UI & Twitter Bootstrap - */ - -.redux-main { - /* Interaction Cues -----------------------------------*/ - .ui-state-disabled { cursor: default !important; } - - - /* Icons - ----------------------------------*/ - - /* states and images */ - .ui-icon { - display: block; - text-indent: -99999px; - overflow: hidden; - background-repeat: no-repeat; - } - - - /* Misc visuals - ----------------------------------*/ - - - /* - * jQuery UI CSS Framework 1.10.0 - * - * Copyright 2013, AUTHORS.txt (http://jqueryui.com/about) - * Dual licensed under the MIT or GPL Version 2 licenses. - * http://jquery.org/license - * - * - * - * To view and modify this theme, visit http://jqueryui.com/themeroller/ - */ - - /* Component containers - ----------------------------------*/ - .ui-widget { font-family: "Helvetica Neue", Helvetica, Arial, sans-serif; font-size:13px; } - .ui-widget .ui-widget { font-size: 1em; } - .ui-widget input, .ui-widget select, .ui-widget textarea, .ui-widget button { font-family: "Helvetica Neue", Helvetica, Arial, sans-serif; font-size: 1em; } - .ui-widget-content { border: 1px solid #aaaaaa; background: #ffffff url(images/ui-bg_glass_75_ffffff_1x400.png) 50% 50% repeat-x; color: #404040; } - .ui-widget-content a { color: #404040; } - .ui-widget-header { - font-weight:bold; - border-color: #0064cd #0064cd #003f81; - border-color: rgba(0, 0, 0, 0.1) rgba(0, 0, 0, 0.1) rgba(0, 0, 0, 0.25); - border:1px solid #666; - } - .ui-widget-header a { color: #222222; } - - /* Interaction states - ----------------------------------*/ - .ui-state-default, .ui-widget-content .ui-state-default, .ui-widget-header .ui-state-default { - - background-color: #e6e6e6; - background-repeat: no-repeat; - background-image: -webkit-gradient(linear, 0 0, 0 100%, from(#ffffff), color-stop(25%, #ffffff), to(#e6e6e6)); - background-image: -webkit-linear-gradient(#ffffff, #ffffff 25%, #e6e6e6); - background-image: -moz-linear-gradient(top, #ffffff, #ffffff 25%, #e6e6e6); - background-image: -ms-linear-gradient(#ffffff, #ffffff 25%, #e6e6e6); - background-image: -o-linear-gradient(#ffffff, #ffffff 25%, #e6e6e6); - background-image: linear-gradient(#ffffff, #ffffff 25%, #e6e6e6); - filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffffff', endColorstr='#e6e6e6', GradientType=0); - - text-shadow: 0 1px 1px rgba(255, 255, 255, 0.75); - - color: #333; - font-size: 13px; - line-height: normal; - border: 1px solid #ccc; - border-bottom-color: #bbb; - -webkit-box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.2), 0 1px 2px rgba(0, 0, 0, 0.05); - -moz-box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.2), 0 1px 2px rgba(0, 0, 0, 0.05); - box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.2), 0 1px 2px rgba(0, 0, 0, 0.05); - -webkit-transition: 0.1s linear background-image; - -moz-transition: 0.1s linear background-image; - -ms-transition: 0.1s linear background-image; - -o-transition: 0.1s linear background-image; - transition: 0.1s linear background-image; - overflow: visible; - - } - - - .ui-state-default a, .ui-state-default a:link, .ui-state-default a:visited { color: #555555; text-decoration: none; } - .ui-state-hover, .ui-widget-content .ui-state-hover, .ui-widget-header .ui-state-hover, .ui-state-focus, .ui-widget-content .ui-state-focus, .ui-widget-header .ui-state-focus { - background-position: 0 -15px; - color: #333; - text-decoration: none; - } - - .ui-state-hover a, .ui-state-hover a:hover, .ui-state-hover a:link, .ui-state-hover a:visited { color: #212121; text-decoration: none; } - .ui-state-active, .ui-widget-content .ui-state-active, .ui-widget-header .ui-state-active { border: 1px solid #aaaaaa; font-weight: normal; color: #212121; } - .ui-state-active a, .ui-state-active a:link, .ui-state-active a:visited { color: #212121; text-decoration: none; } - .ui-widget :active { outline: none; } - - /* Interaction Cues - ----------------------------------*/ - - - .ui-state-highlight p, .ui-state-error p, .ui-state-default p{ - font-size: 13px; - font-weight: normal; - line-height: 18px; - margin:7px 15px; - } - .ui-state-highlight, .ui-widget-content .ui-state-highlight, .ui-widget-header .ui-state-highlight { - - - position: relative; - margin-bottom: 18px; - color: #404040; - background-color: #eedc94; - background-repeat: repeat-x; - background-image: -khtml-gradient(linear, left top, left bottom, from(#fceec1), to(#eedc94)); - background-image: -moz-linear-gradient(top, #fceec1, #eedc94); - background-image: -ms-linear-gradient(top, #fceec1, #eedc94); - background-image: -webkit-gradient(linear, left top, left bottom, color-stop(0%, #fceec1), color-stop(100%, #eedc94)); - background-image: -webkit-linear-gradient(top, #fceec1, #eedc94); - background-image: -o-linear-gradient(top, #fceec1, #eedc94); - background-image: linear-gradient(top, #fceec1, #eedc94); - filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#fceec1', endColorstr='#eedc94', GradientType=0); - text-shadow: 0 -1px 0 rgba(0, 0, 0, 0.25); - border-color: #eedc94 #eedc94 #e4c652; - border-color: rgba(0, 0, 0, 0.1) rgba(0, 0, 0, 0.1) rgba(0, 0, 0, 0.25); - text-shadow: 0 1px 0 rgba(255, 255, 255, 0.5); - border-width: 1px; - border-style: solid; - -webkit-border-radius: 4px; - -moz-border-radius: 4px; - border-radius: 4px; - -webkit-box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.25); - -moz-box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.25); - box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.25); - - - } - .ui-state-highlight a, .ui-widget-content .ui-state-highlight a,.ui-widget-header .ui-state-highlight a { color: #363636; } - .ui-state-error, .ui-widget-content .ui-state-error, .ui-widget-header .ui-state-error { - - - position: relative; - margin-bottom: 18px; - color: #ffffff; - border-width: 1px; - border-style: solid; - -webkit-border-radius: 4px; - -moz-border-radius: 4px; - border-radius: 4px; - -webkit-box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.25); - -moz-box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.25); - box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.25); - background-color: #c43c35; - background-repeat: repeat-x; - background-image: -khtml-gradient(linear, left top, left bottom, from(#ee5f5b), to(#c43c35)); - background-image: -moz-linear-gradient(top, #ee5f5b, #c43c35); - background-image: -ms-linear-gradient(top, #ee5f5b, #c43c35); - background-image: -webkit-gradient(linear, left top, left bottom, color-stop(0%, #ee5f5b), color-stop(100%, #c43c35)); - background-image: -webkit-linear-gradient(top, #ee5f5b, #c43c35); - background-image: -o-linear-gradient(top, #ee5f5b, #c43c35); - background-image: linear-gradient(top, #ee5f5b, #c43c35); - filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ee5f5b', endColorstr='#c43c35', GradientType=0); - text-shadow: 0 -1px 0 rgba(0, 0, 0, 0.25); - border-color: #c43c35 #c43c35 #882a25; - border-color: rgba(0, 0, 0, 0.1) rgba(0, 0, 0, 0.1) rgba(0, 0, 0, 0.25); - - - } - .ui-state-error a, .ui-widget-content .ui-state-error a, .ui-widget-header .ui-state-error a { color: #cd0a0a; } - .ui-state-error-text, .ui-widget-content .ui-state-error-text, .ui-widget-header .ui-state-error-text { color: #cd0a0a; } - .ui-priority-primary, .ui-widget-content .ui-priority-primary, .ui-widget-header .ui-priority-primary { font-weight: bold; } - .ui-priority-secondary, .ui-widget-content .ui-priority-secondary, .ui-widget-header .ui-priority-secondary { opacity: .7; filter:Alpha(Opacity=70); font-weight: normal; } - .ui-state-disabled, .ui-widget-content .ui-state-disabled, .ui-widget-header .ui-state-disabled { opacity: .35; filter:Alpha(Opacity=35); background-image: none; } - .ui-state-disabled .ui-icon { filter:Alpha(Opacity=35); } /* For IE8 - See #6059 */ - - - /* Icons - ----------------------------------*/ - - /* states and images */ - .ui-icon { width: 16px; height: 16px; background-image: url(images/ui-icons_222222_256x240.png); } - .ui-widget-content .ui-icon {background-image: url(images/ui-icons_222222_256x240.png); } - .ui-widget-header .ui-icon {background-image: url(images/ui-icons_222222_256x240.png); } - .ui-state-default .ui-icon { background-image: url(images/ui-icons_888888_256x240.png); } - .ui-state-hover .ui-icon, .ui-state-focus .ui-icon {background-image: url(images/ui-icons_454545_256x240.png); } - .ui-state-active .ui-icon {background-image: url(images/ui-icons_454545_256x240.png); } - .ui-state-highlight .ui-icon {background-image: url(images/ui-icons_2e83ff_256x240.png); } - .ui-state-error .ui-icon, .ui-state-error-text .ui-icon {background-image: url(images/ui-icons_f6cf3b_256x240.png); } - - /* positioning */ - .ui-icon-carat-1-n { background-position: 0 0; } - .ui-icon-carat-1-ne { background-position: -16px 0; } - .ui-icon-carat-1-e { background-position: -32px 0; } - .ui-icon-carat-1-se { background-position: -48px 0; } - .ui-icon-carat-1-s { background-position: -64px 0; } - .ui-icon-carat-1-sw { background-position: -80px 0; } - .ui-icon-carat-1-w { background-position: -96px 0; } - .ui-icon-carat-1-nw { background-position: -112px 0; } - .ui-icon-carat-2-n-s { background-position: -128px 0; } - .ui-icon-carat-2-e-w { background-position: -144px 0; } - .ui-icon-triangle-1-n { background-position: 0 -16px; } - .ui-icon-triangle-1-ne { background-position: -16px -16px; } - .ui-icon-triangle-1-e { background-position: -32px -16px; } - .ui-icon-triangle-1-se { background-position: -48px -16px; } - .ui-icon-triangle-1-s { background-position: -64px -16px; } - .ui-icon-triangle-1-sw { background-position: -80px -16px; } - .ui-icon-triangle-1-w { background-position: -96px -16px; } - .ui-icon-triangle-1-nw { background-position: -112px -16px; } - .ui-icon-triangle-2-n-s { background-position: -128px -16px; } - .ui-icon-triangle-2-e-w { background-position: -144px -16px; } - .ui-icon-arrow-1-n { background-position: 0 -32px; } - .ui-icon-arrow-1-ne { background-position: -16px -32px; } - .ui-icon-arrow-1-e { background-position: -32px -32px; } - .ui-icon-arrow-1-se { background-position: -48px -32px; } - .ui-icon-arrow-1-s { background-position: -64px -32px; } - .ui-icon-arrow-1-sw { background-position: -80px -32px; } - .ui-icon-arrow-1-w { background-position: -96px -32px; } - .ui-icon-arrow-1-nw { background-position: -112px -32px; } - .ui-icon-arrow-2-n-s { background-position: -128px -32px; } - .ui-icon-arrow-2-ne-sw { background-position: -144px -32px; } - .ui-icon-arrow-2-e-w { background-position: -160px -32px; } - .ui-icon-arrow-2-se-nw { background-position: -176px -32px; } - .ui-icon-arrowstop-1-n { background-position: -192px -32px; } - .ui-icon-arrowstop-1-e { background-position: -208px -32px; } - .ui-icon-arrowstop-1-s { background-position: -224px -32px; } - .ui-icon-arrowstop-1-w { background-position: -240px -32px; } - .ui-icon-arrowthick-1-n { background-position: 0 -48px; } - .ui-icon-arrowthick-1-ne { background-position: -16px -48px; } - .ui-icon-arrowthick-1-e { background-position: -32px -48px; } - .ui-icon-arrowthick-1-se { background-position: -48px -48px; } - .ui-icon-arrowthick-1-s { background-position: -64px -48px; } - .ui-icon-arrowthick-1-sw { background-position: -80px -48px; } - .ui-icon-arrowthick-1-w { background-position: -96px -48px; } - .ui-icon-arrowthick-1-nw { background-position: -112px -48px; } - .ui-icon-arrowthick-2-n-s { background-position: -128px -48px; } - .ui-icon-arrowthick-2-ne-sw { background-position: -144px -48px; } - .ui-icon-arrowthick-2-e-w { background-position: -160px -48px; } - .ui-icon-arrowthick-2-se-nw { background-position: -176px -48px; } - .ui-icon-arrowthickstop-1-n { background-position: -192px -48px; } - .ui-icon-arrowthickstop-1-e { background-position: -208px -48px; } - .ui-icon-arrowthickstop-1-s { background-position: -224px -48px; } - .ui-icon-arrowthickstop-1-w { background-position: -240px -48px; } - .ui-icon-arrowreturnthick-1-w { background-position: 0 -64px; } - .ui-icon-arrowreturnthick-1-n { background-position: -16px -64px; } - .ui-icon-arrowreturnthick-1-e { background-position: -32px -64px; } - .ui-icon-arrowreturnthick-1-s { background-position: -48px -64px; } - .ui-icon-arrowreturn-1-w { background-position: -64px -64px; } - .ui-icon-arrowreturn-1-n { background-position: -80px -64px; } - .ui-icon-arrowreturn-1-e { background-position: -96px -64px; } - .ui-icon-arrowreturn-1-s { background-position: -112px -64px; } - .ui-icon-arrowrefresh-1-w { background-position: -128px -64px; } - .ui-icon-arrowrefresh-1-n { background-position: -144px -64px; } - .ui-icon-arrowrefresh-1-e { background-position: -160px -64px; } - .ui-icon-arrowrefresh-1-s { background-position: -176px -64px; } - .ui-icon-arrow-4 { background-position: 0 -80px; } - .ui-icon-arrow-4-diag { background-position: -16px -80px; } - .ui-icon-extlink { background-position: -32px -80px; } - .ui-icon-newwin { background-position: -48px -80px; } - .ui-icon-refresh { background-position: -64px -80px; } - .ui-icon-shuffle { background-position: -80px -80px; } - .ui-icon-transfer-e-w { background-position: -96px -80px; } - .ui-icon-transferthick-e-w { background-position: -112px -80px; } - .ui-icon-folder-collapsed { background-position: 0 -96px; } - .ui-icon-folder-open { background-position: -16px -96px; } - .ui-icon-document { background-position: -32px -96px; } - .ui-icon-document-b { background-position: -48px -96px; } - .ui-icon-note { background-position: -64px -96px; } - .ui-icon-mail-closed { background-position: -80px -96px; } - .ui-icon-mail-open { background-position: -96px -96px; } - .ui-icon-suitcase { background-position: -112px -96px; } - .ui-icon-comment { background-position: -128px -96px; } - .ui-icon-person { background-position: -144px -96px; } - .ui-icon-print { background-position: -160px -96px; } - .ui-icon-trash { background-position: -176px -96px; } - .ui-icon-locked { background-position: -192px -96px; } - .ui-icon-unlocked { background-position: -208px -96px; } - .ui-icon-bookmark { background-position: -224px -96px; } - .ui-icon-tag { background-position: -240px -96px; } - .ui-icon-home { background-position: 0 -112px; } - .ui-icon-flag { background-position: -16px -112px; } - .ui-icon-calendar { background-position: -32px -112px; } - .ui-icon-cart { background-position: -48px -112px; } - .ui-icon-pencil { background-position: -64px -112px; } - .ui-icon-clock { background-position: -80px -112px; } - .ui-icon-disk { background-position: -96px -112px; } - .ui-icon-calculator { background-position: -112px -112px; } - .ui-icon-zoomin { background-position: -128px -112px; } - .ui-icon-zoomout { background-position: -144px -112px; } - .ui-icon-search { background-position: -160px -112px; } - .ui-icon-wrench { background-position: -176px -112px; } - .ui-icon-gear { background-position: -192px -112px; } - .ui-icon-heart { background-position: -208px -112px; } - .ui-icon-star { background-position: -224px -112px; } - .ui-icon-link { background-position: -240px -112px; } - .ui-icon-cancel { background-position: 0 -128px; } - .ui-icon-plus { background-position: -16px -128px; } - .ui-icon-plusthick { background-position: -32px -128px; } - .ui-icon-minus { background-position: -48px -128px; } - .ui-icon-minusthick { background-position: -64px -128px; } - .ui-icon-close { background-position: -80px -128px; } - .ui-icon-closethick { background-position: -96px -128px; } - .ui-icon-key { background-position: -112px -128px; } - .ui-icon-lightbulb { background-position: -128px -128px; } - .ui-icon-scissors { background-position: -144px -128px; } - .ui-icon-clipboard { background-position: -160px -128px; } - .ui-icon-copy { background-position: -176px -128px; } - .ui-icon-contact { background-position: -192px -128px; } - .ui-icon-image { background-position: -208px -128px; } - .ui-icon-video { background-position: -224px -128px; } - .ui-icon-script { background-position: -240px -128px; } - .ui-icon-alert { background-position: 0 -144px; } - .ui-icon-info { background-position: -16px -144px; } - .ui-icon-notice { background-position: -32px -144px; } - .ui-icon-help { background-position: -48px -144px; } - .ui-icon-check { background-position: -64px -144px; } - .ui-icon-bullet { background-position: -80px -144px; } - .ui-icon-radio-off { background-position: -96px -144px; } - .ui-icon-radio-on { background-position: -112px -144px; } - .ui-icon-pin-w { background-position: -128px -144px; } - .ui-icon-pin-s { background-position: -144px -144px; } - .ui-icon-play { background-position: 0 -160px; } - .ui-icon-pause { background-position: -16px -160px; } - .ui-icon-seek-next { background-position: -32px -160px; } - .ui-icon-seek-prev { background-position: -48px -160px; } - .ui-icon-seek-end { background-position: -64px -160px; } - .ui-icon-seek-start { background-position: -80px -160px; } - /* ui-icon-seek-first is deprecated, use ui-icon-seek-start instead */ - .ui-icon-seek-first { background-position: -80px -160px; } - .ui-icon-stop { background-position: -96px -160px; } - .ui-icon-eject { background-position: -112px -160px; } - .ui-icon-volume-off { background-position: -128px -160px; } - .ui-icon-volume-on { background-position: -144px -160px; } - .ui-icon-power { background-position: 0 -176px; } - .ui-icon-signal-diag { background-position: -16px -176px; } - .ui-icon-signal { background-position: -32px -176px; } - .ui-icon-battery-0 { background-position: -48px -176px; } - .ui-icon-battery-1 { background-position: -64px -176px; } - .ui-icon-battery-2 { background-position: -80px -176px; } - .ui-icon-battery-3 { background-position: -96px -176px; } - .ui-icon-circle-plus { background-position: 0 -192px; } - .ui-icon-circle-minus { background-position: -16px -192px; } - .ui-icon-circle-close { background-position: -32px -192px; } - .ui-icon-circle-triangle-e { background-position: -48px -192px; } - .ui-icon-circle-triangle-s { background-position: -64px -192px; } - .ui-icon-circle-triangle-w { background-position: -80px -192px; } - .ui-icon-circle-triangle-n { background-position: -96px -192px; } - .ui-icon-circle-arrow-e { background-position: -112px -192px; } - .ui-icon-circle-arrow-s { background-position: -128px -192px; } - .ui-icon-circle-arrow-w { background-position: -144px -192px; } - .ui-icon-circle-arrow-n { background-position: -160px -192px; } - .ui-icon-circle-zoomin { background-position: -176px -192px; } - .ui-icon-circle-zoomout { background-position: -192px -192px; } - .ui-icon-circle-check { background-position: -208px -192px; } - .ui-icon-circlesmall-plus { background-position: 0 -208px; } - .ui-icon-circlesmall-minus { background-position: -16px -208px; } - .ui-icon-circlesmall-close { background-position: -32px -208px; } - .ui-icon-squaresmall-plus { background-position: -48px -208px; } - .ui-icon-squaresmall-minus { background-position: -64px -208px; } - .ui-icon-squaresmall-close { background-position: -80px -208px; } - .ui-icon-grip-dotted-vertical { background-position: 0 -224px; } - .ui-icon-grip-dotted-horizontal { background-position: -16px -224px; } - .ui-icon-grip-solid-vertical { background-position: -32px -224px; } - .ui-icon-grip-solid-horizontal { background-position: -48px -224px; } - .ui-icon-gripsmall-diagonal-se { background-position: -64px -224px; } - .ui-icon-grip-diagonal-se { background-position: -80px -224px; } - - - /* Misc visuals - ----------------------------------*/ - - /* Corner radius */ - .ui-corner-all, - .ui-corner-top, - .ui-corner-left, - .ui-corner-tl { - -moz-border-radius-topleft: 4px; - -webkit-border-top-left-radius: 4px; - -khtml-border-top-left-radius: 4px; - border-top-left-radius: 4px; - } - .ui-corner-all, - .ui-corner-top, - .ui-corner-right, - .ui-corner-tr { - -moz-border-radius-topright: 4px; - -webkit-border-top-right-radius: 4px; - -khtml-border-top-right-radius: 4px; - border-top-right-radius: 4px; - } - .ui-corner-all, - .ui-corner-bottom, - .ui-corner-left, - .ui-corner-bl { - -moz-border-radius-bottomleft: 4px; - -webkit-border-bottom-left-radius: 4px; - -khtml-border-bottom-left-radius: 4px; - border-bottom-left-radius: 4px; - } - .ui-corner-all, - .ui-corner-bottom, - .ui-corner-right, - .ui-corner-br { - -moz-border-radius-bottomright: 4px; - -webkit-border-bottom-right-radius: 4px; - -khtml-border-bottom-right-radius: 4px; - border-bottom-right-radius: 4px; - } - - - /* Overlays */ - - .ui-widget-overlay { - background: #aaaaaa url(images/ui-bg_flat_0_aaaaaa_40x100.png) 50% 50% repeat-x; - opacity: .30; - filter:Alpha(Opacity=30); - } - - .ui-widget-shadow { - margin: -8px 0 0 -8px; - padding: 8px; - background: #aaaaaa url(images/ui-bg_flat_0_aaaaaa_40x100.png) 50% 50% repeat-x; - opacity: .30;filter:Alpha(Opacity=30); - -moz-border-radius: 8px; - -khtml-border-radius: 8px; - -webkit-border-radius: 8px; - border-radius: 8px; - } - - /* - * jQuery UI Accordion 1.10.0 - * - * Copyright 2013, AUTHORS.txt (http://jqueryui.com/about) - * Dual licensed under the MIT or GPL Version 2 licenses. - * http://jquery.org/license - * - * http://jqueryui.com/accordion/ - */ - - /* IE/Win - Fix animation bug - #4615 */ - - .ui-accordion { - width: 100%; - } - .ui-accordion .ui-accordion-header { - cursor: pointer; - position: relative; - margin-top: 1px; - zoom: 1; - font-weight:bold; - } - .ui-accordion .ui-accordion-li-fix { - display: inline; - } - .ui-accordion .ui-accordion-header-active { - border-bottom: 0 !important; - } - .ui-accordion .ui-accordion-header a { - display: block; - font-size: 1em; - padding: .5em .5em .5em 1.7em; - } - .ui-accordion-icons .ui-accordion-header a { - padding-left: 2.2em; - } - .ui-accordion .ui-accordion-header .ui-icon { - position: absolute; - left: .5em; - top: 50%; - margin-top: -8px; - } - .ui-accordion .ui-accordion-content { - padding: 1em 2.2em; - border-top: 0; - margin-top: -2px; - position: relative; - top: 1px; - margin-bottom: 2px; - overflow: auto; - display: none; - zoom: 1; - } - .ui-accordion .ui-accordion-content-active { - display: block; - } - - - /* - * jQuery UI Button 1.10.0 - * - * Copyright 2013, AUTHORS.txt (http://jqueryui.com/about) - * Dual licensed under the MIT or GPL Version 2 licenses. - * http://jquery.org/license - * - * http://docs.jquery.com/UI/Button#theming - */ - - .ui-button { - - cursor: pointer; - display: inline-block; - background-color: #e6e6e6; - background-repeat: no-repeat; - background-image: -webkit-gradient(linear, 0 0, 0 100%, from(#ffffff), color-stop(25%, #ffffff), to(#e6e6e6)); - background-image: -webkit-linear-gradient(#ffffff, #ffffff 25%, #e6e6e6); - background-image: -moz-linear-gradient(top, #ffffff, #ffffff 25%, #e6e6e6); - background-image: -ms-linear-gradient(#ffffff, #ffffff 25%, #e6e6e6); - background-image: -o-linear-gradient(#ffffff, #ffffff 25%, #e6e6e6); - background-image: linear-gradient(#ffffff, #ffffff 25%, #e6e6e6); - filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffffff', endColorstr='#e6e6e6', GradientType=0); - padding: 5px 14px 6px; - margin: 0; - text-shadow: 0 1px 1px rgba(255, 255, 255, 0.75); - color: #333; - font-size: 13px; - line-height: normal; - border: 1px solid #ccc; - border-bottom-color: #bbb; - - -webkit-box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.2), 0 1px 2px rgba(0, 0, 0, 0.05); - -moz-box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.2), 0 1px 2px rgba(0, 0, 0, 0.05); - box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.2), 0 1px 2px rgba(0, 0, 0, 0.05); - -webkit-transition: 0.1s linear background-image; - -moz-transition: 0.1s linear background-image; - -ms-transition: 0.1s linear background-image; - -o-transition: 0.1s linear background-image; - transition: 0.1s linear background-image; - overflow: visible; - } /* the overflow property removes extra width in IE */ - - .ui-button-primary { - color: #ffffff; - background-color: #0064cd; - background-repeat: repeat-x; - background-image: -khtml-gradient(linear, left top, left bottom, from(#049cdb), to(#0064cd)); - background-image: -moz-linear-gradient(top, #049cdb, #0064cd); - background-image: -ms-linear-gradient(top, #049cdb, #0064cd); - background-image: -webkit-gradient(linear, left top, left bottom, color-stop(0%, #049cdb), color-stop(100%, #0064cd)); - background-image: -webkit-linear-gradient(top, #049cdb, #0064cd); - background-image: -o-linear-gradient(top, #049cdb, #0064cd); - background-image: linear-gradient(top, #049cdb, #0064cd); - filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#049cdb', endColorstr='#0064cd', GradientType=0); - text-shadow: 0 -1px 0 rgba(0, 0, 0, 0.25); - border-color: #0064cd #0064cd #003f81; - border-color: rgba(0, 0, 0, 0.1) rgba(0, 0, 0, 0.1) rgba(0, 0, 0, 0.25); - } - - - .ui-button-success{ - color:#ffffff; - background-color: #57a957; - background-repeat: repeat-x; - background-image: -khtml-gradient(linear, left top, left bottom, from(#62c462), to(#57a957)); - background-image: -moz-linear-gradient(top, #62c462, #57a957); - background-image: -ms-linear-gradient(top, #62c462, #57a957); - background-image: -webkit-gradient(linear, left top, left bottom, color-stop(0%, #62c462), color-stop(100%, #57a957)); - background-image: -webkit-linear-gradient(top, #62c462, #57a957); - background-image: -o-linear-gradient(top, #62c462, #57a957); - background-image: linear-gradient(top, #62c462, #57a957); - filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#62c462', endColorstr='#57a957', GradientType=0); - text-shadow: 0 -1px 0 rgba(0, 0, 0, 0.25); - border-color: #57a957 #57a957 #3d773d; - border-color: rgba(0, 0, 0, 0.1) rgba(0, 0, 0, 0.1) rgba(0, 0, 0, 0.25); - } - - .ui-button-error{ - color:#ffffff; - background-color: #c43c35; - background-repeat: repeat-x; - background-image: -khtml-gradient(linear, left top, left bottom, from(#ee5f5b), to(#c43c35)); - background-image: -moz-linear-gradient(top, #ee5f5b, #c43c35); - background-image: -ms-linear-gradient(top, #ee5f5b, #c43c35); - background-image: -webkit-gradient(linear, left top, left bottom, color-stop(0%, #ee5f5b), color-stop(100%, #c43c35)); - background-image: -webkit-linear-gradient(top, #ee5f5b, #c43c35); - background-image: -o-linear-gradient(top, #ee5f5b, #c43c35); - background-image: linear-gradient(top, #ee5f5b, #c43c35); - filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ee5f5b', endColorstr='#c43c35', GradientType=0); - text-shadow: 0 -1px 0 rgba(0, 0, 0, 0.25); - border-color: #c43c35 #c43c35 #882a25; - border-color: rgba(0, 0, 0, 0.1) rgba(0, 0, 0, 0.1) rgba(0, 0, 0, 0.25); - } - - .ui-button-icon-only { width: 2.2em; } /* to make room for the icon, a width needs to be set here */ - button.ui-button-icon-only { } /* button elements seem to need a little more width */ - .ui-button-icons-only { width: 3.4em; } - button.ui-button-icons-only { width: 3.7em; } - - /*button text element */ - - .ui-button .ui-button-text { display: block; } - .ui-button-text-only .ui-button-text { } - .ui-button-icon-only .ui-button-text, .ui-button-icons-only .ui-button-text { padding: .4em; text-indent: -9999999px; /*tempfix*/ display:none;} - .ui-button-text-icon-primary .ui-button-text, .ui-button-text-icons .ui-button-text { padding: .4em 1em .4em 2.1em; } - .ui-button-text-icon-secondary .ui-button-text, .ui-button-text-icons .ui-button-text { padding: .4em 2.1em .4em 1em; } - .ui-button-text-icons .ui-button-text { padding-left: 2.1em; padding-right: 2.1em; } - /* no icon support for input elements, provide padding by default */ - /* input.ui-button { padding: .4em 1em; } */ - - /*button icon element(s) */ - .ui-button-icon-only .ui-icon, .ui-button-text-icon-primary .ui-icon, .ui-button-text-icon-secondary .ui-icon, .ui-button-text-icons .ui-icon, .ui-button-icons-only .ui-icon { top: 50%; margin-top:-3px; margin-bottom:3px; } - .ui-button-icon-only .ui-icon { left: 50%; margin-left: -8px; } - .ui-button-text-icon-primary .ui-button-icon-primary, .ui-button-text-icons .ui-button-icon-primary, .ui-button-icons-only .ui-button-icon-primary { left: .5em; } - .ui-button-text-icon-secondary .ui-button-icon-secondary, .ui-button-text-icons .ui-button-icon-secondary, .ui-button-icons-only .ui-button-icon-secondary { right: .5em; } - .ui-button-text-icons .ui-button-icon-secondary, .ui-button-icons-only .ui-button-icon-secondary { right: .5em; } - - /*button sets*/ - - - .ui-buttonset { margin-right: 7px; } - .ui-buttonset .ui-state-active { - color: #ffffff; - background-color: #0064cd; - background-repeat: repeat-x; - background-image: -khtml-gradient(linear, left top, left bottom, from(#049cdb), to(#0064cd)); - background-image: -moz-linear-gradient(top, #049cdb, #0064cd); - background-image: -ms-linear-gradient(top, #049cdb, #0064cd); - background-image: -webkit-gradient(linear, left top, left bottom, color-stop(0%, #049cdb), color-stop(100%, #0064cd)); - background-image: -webkit-linear-gradient(top, #049cdb, #0064cd); - background-image: -o-linear-gradient(top, #049cdb, #0064cd); - background-image: linear-gradient(top, #049cdb, #0064cd); - filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#049cdb', endColorstr='#0064cd', GradientType=0); - text-shadow: 0 -1px 0 rgba(0, 0, 0, 0.25); - border-color: #0064cd #0064cd #003f81; - border-color: rgba(0, 0, 0, 0.1) rgba(0, 0, 0, 0.1) rgba(0, 0, 0, 0.25); - } - .ui-buttonset .ui-button { margin-left: 0; margin-right: 0; } - - /* workarounds */ - button.ui-button::-moz-focus-inner { border: 0; padding: 0; } /* reset extra padding in Firefox */ - - /* - * jQuery UI Datepicker 1.9.0 - * - * Copyright 2012-10-11, AUTHORS.txt (http://jqueryui.com/about) - * Dual licensed under the MIT or GPL Version 2 licenses. - * http://jquery.org/license - * - * http://jqueryui.com/datepicker/ - */ - .ui-datepicker { width: 17em; padding: .2em .2em 0; display: none; } - .ui-datepicker .ui-datepicker-header { position:relative; padding:.2em 0; border:0px; font-weight: bold; width: 100%; padding: 4px 0; background-color: #f5f5f5; color: #808080; } - .ui-datepicker .ui-datepicker-prev, .ui-datepicker .ui-datepicker-next { position:absolute; top: 2px; width: 1.8em; height: 1.8em; } - - .ui-datepicker .ui-datepicker-prev-hover, .ui-datepicker .ui-datepicker-next-hover { /*top: 1px;*/ } - .ui-datepicker .ui-datepicker-prev { left:2px; } - .ui-datepicker .ui-datepicker-next { right:2px; } - - .ui-datepicker .ui-datepicker-prev-hover { /*left:1px;*/ } - .ui-datepicker .ui-datepicker-next-hover { /*right:1px;*/ } - - .ui-datepicker .ui-datepicker-prev span, .ui-datepicker .ui-datepicker-next span { display: block; position: absolute; left: 50%; margin-left: -8px; top: 50%; margin-top: -8px; } - .ui-datepicker .ui-datepicker-title { margin: 0 2.3em; line-height: 1.8em; text-align: center; } - .ui-datepicker .ui-datepicker-title select { font-size:1em; margin:1px 0; } - .ui-datepicker select.ui-datepicker-month-year {width: 100%;} - .ui-datepicker select.ui-datepicker-month, - .ui-datepicker select.ui-datepicker-year { width: 49%;} - .ui-datepicker table {width: 100%; font-size: .9em; border-collapse: collapse; margin:0 0 .4em; } - .ui-datepicker th { padding: .7em .3em; text-align: center; font-weight: bold; border: 0; } - .ui-datepicker td { border: 0; padding: 1px; } - .ui-datepicker td span, .ui-datepicker td a { display: block; padding: .2em; text-align: right; text-decoration: none; } - .ui-datepicker .ui-datepicker-buttonpane { background-image: none; margin: .7em 0 0 0; padding:0 .2em; border-left: 0; border-right: 0; border-bottom: 0; } - .ui-datepicker .ui-datepicker-buttonpane button { float: right; margin: .5em .2em .4em; cursor: pointer; padding: .2em .6em .3em .6em; width:auto; overflow:visible; } - .ui-datepicker .ui-datepicker-buttonpane button.ui-datepicker-current { float:left; } - - /* with multiple calendars */ - .ui-datepicker.ui-datepicker-multi { width:auto; } - .ui-datepicker-multi .ui-datepicker-group { float:left; } - .ui-datepicker-multi .ui-datepicker-group table { width:95%; margin:0 auto .4em; } - .ui-datepicker-multi-2 .ui-datepicker-group { width:50%; } - .ui-datepicker-multi-3 .ui-datepicker-group { width:33.3%; } - .ui-datepicker-multi-4 .ui-datepicker-group { width:25%; } - .ui-datepicker-multi .ui-datepicker-group-last .ui-datepicker-header { border-left-width:0; } - .ui-datepicker-multi .ui-datepicker-group-middle .ui-datepicker-header { border-left-width:0; } - .ui-datepicker-multi .ui-datepicker-buttonpane { clear:left; } - .ui-datepicker-row-break { clear:both; width:100%; font-size:0em; } - - /* RTL support */ - .ui-datepicker-rtl { direction: rtl; } - .ui-datepicker-rtl .ui-datepicker-prev { right: 2px; left: auto; } - .ui-datepicker-rtl .ui-datepicker-next { left: 2px; right: auto; } - .ui-datepicker-rtl .ui-datepicker-prev:hover { right: 1px; left: auto; } - .ui-datepicker-rtl .ui-datepicker-next:hover { left: 1px; right: auto; } - .ui-datepicker-rtl .ui-datepicker-buttonpane { clear:right; } - .ui-datepicker-rtl .ui-datepicker-buttonpane button { float: left; } - .ui-datepicker-rtl .ui-datepicker-buttonpane button.ui-datepicker-current { float:right; } - .ui-datepicker-rtl .ui-datepicker-group { float:right; } - .ui-datepicker-rtl .ui-datepicker-group-last .ui-datepicker-header { border-right-width:0; border-left-width:1px; } - .ui-datepicker-rtl .ui-datepicker-group-middle .ui-datepicker-header { border-right-width:0; border-left-width:1px; } - - /* IE6 IFRAME FIX (taken from datepicker 1.5.3 */ - .ui-datepicker-cover { - display: none; /*sorry for IE5*/ - display: block; /*sorry for IE5*/ - position: absolute; /*must have*/ - z-index: -1; /*must have*/ - filter: mask(); /*must have*/ - top: -4px; /*must have*/ - left: -4px; /*must have*/ - width: 200px; /*must have*/ - height: 200px; /*must have*/ - } - - .ui-datepicker th{ - font-weight: bold; - color: gray; - } - - .ui-datepicker-today a:hover{ - background-color: #808080; - color: #ffffff; - - } - .ui-datepicker-today a{ - background-color: #BFBFBF; - cursor: pointer; - padding: 0 4px; - margin-bottom:0px; - - } - - - .ui-datepicker td a{ - margin-bottom:0px; - border:0px; - } - - .ui-datepicker td:hover{ - color: #ffffff; - } - - .ui-datepicker td .ui-state-default { - border:0px; - background:none; - margin-bottom:0px; - padding:5px; - color:gray; - text-align: center; - filter:none; - } - - - .ui-datepicker td .ui-state-active{ - background:#BFBFBF; - margin-bottom:0px; - font-size:normal; - text-shadow: 0px; - color: #ffffff; - -webkit-border-radius: 4px; - -moz-border-radius: 4px; - border-radius: 4px; - } - - .ui-datepicker td .ui-state-hover { - color: #ffffff; - background: #0064cd; - background-color: #0064cd; - background-repeat: repeat-x; - background-image: -khtml-gradient(linear, left top, left bottom, from(#049cdb), to(#0064cd)); - background-image: -moz-linear-gradient(top, #049cdb, #0064cd); - background-image: -ms-linear-gradient(top, #049cdb, #0064cd); - background-image: -webkit-gradient(linear, left top, left bottom, color-stop(0%, #049cdb), color-stop(100%, #0064cd)); - background-image: -webkit-linear-gradient(top, #049cdb, #0064cd); - background-image: -o-linear-gradient(top, #049cdb, #0064cd); - background-image: linear-gradient(top, #049cdb, #0064cd); - filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#049cdb', endColorstr='#0064cd', GradientType=0); - text-shadow: 0 -1px 0 rgba(0, 0, 0, 0.25); - border-color: #0064cd #0064cd #003f81; - border-color: rgba(0, 0, 0, 0.1) rgba(0, 0, 0, 0.1) rgba(0, 0, 0, 0.25); - -webkit-border-radius: 4px; - -moz-border-radius: 4px; - -khtml-border-radius: 4px; - border-radius: 4px; - } - - .ui-widget-content { - border: 1px solid #dfdfdf; - } - .ui-datepicker table { background: #fff; } - - .placeholder { - background:#f9f9f9 !important; - border: 1px dashed #bbb !important; - } - -} \ No newline at end of file diff --git a/library/admin/ReduxCore/assets/css/vendor/jquery-ui-bootstrap/jquery-ui-1.10.0.custom.scss b/library/admin/ReduxCore/assets/css/vendor/jquery-ui-bootstrap/jquery-ui-1.10.0.custom.scss deleted file mode 100644 index 1b81be8b..00000000 --- a/library/admin/ReduxCore/assets/css/vendor/jquery-ui-bootstrap/jquery-ui-1.10.0.custom.scss +++ /dev/null @@ -1,799 +0,0 @@ -/*! - * jQuery UI Bootstrap (0.5) - * http://addyosmani.github.com/jquery-ui-bootstrap - * - * Copyright 2012 - 2013, Addy Osmani - * Dual licensed under the MIT or GPL Version 2 licenses. - * - * Portions copyright jQuery UI & Twitter Bootstrap - */ - -.redux-container, .control-section-redux, .control-panel-redux, .redux-metabox { - /* Interaction Cues -----------------------------------*/ - .ui-state-disabled { cursor: default !important; } - - - /* Icons - ----------------------------------*/ - - /* states and images */ - .ui-icon { - display: block; - text-indent: -99999px; - overflow: hidden; - background-repeat: no-repeat; - } - - - /* Misc visuals - ----------------------------------*/ - - - /* - * jQuery UI CSS Framework 1.10.0 - * - * Copyright 2013, AUTHORS.txt (http://jqueryui.com/about) - * Dual licensed under the MIT or GPL Version 2 licenses. - * http://jquery.org/license - * - * - * - * To view and modify this theme, visit http://jqueryui.com/themeroller/ - */ - - /* Component containers - ----------------------------------*/ - //.ui-widget { font-size:13px; } - //.ui-widget .ui-widget { font-size: 1em; } - //.ui-widget input, .ui-widget select, .ui-widget textarea, .ui-widget button { font-size: 1em; } - .ui-widget-content { border: 1px solid #aaaaaa; background: #ffffff url(images/ui-bg_glass_75_ffffff_1x400.png) 50% 50% repeat-x; color: #404040; } - //.ui-widget-content a { color: #404040; } - .ui-widget-header { - font-weight:bold; - border-color: #0064cd #0064cd #003f81; - border-color: rgba(0, 0, 0, 0.1) rgba(0, 0, 0, 0.1) rgba(0, 0, 0, 0.25); - border:1px solid #666; - } - .ui-widget-header a { color: #222222; } - - /* Interaction states - ----------------------------------*/ - .ui-state-default, .ui-widget-content .ui-state-default, .ui-widget-header .ui-state-default { - - background-color: #e6e6e6; - background-repeat: no-repeat; - background-image: -webkit-gradient(linear, 0 0, 0 100%, from(#ffffff), color-stop(25%, #ffffff), to(#e6e6e6)); - background-image: -webkit-linear-gradient(#ffffff, #ffffff 25%, #e6e6e6); - background-image: -moz-linear-gradient(top, #ffffff, #ffffff 25%, #e6e6e6); - background-image: -ms-linear-gradient(#ffffff, #ffffff 25%, #e6e6e6); - background-image: -o-linear-gradient(#ffffff, #ffffff 25%, #e6e6e6); - background-image: linear-gradient(#ffffff, #ffffff 25%, #e6e6e6); - filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffffff', endColorstr='#e6e6e6', GradientType=0); - - text-shadow: 0 1px 1px rgba(255, 255, 255, 0.75); - - color: #333; - font-size: 13px; - line-height: normal; - border: 1px solid #ccc; - border-bottom-color: #bbb; - -webkit-box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.2), 0 1px 2px rgba(0, 0, 0, 0.05); - -moz-box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.2), 0 1px 2px rgba(0, 0, 0, 0.05); - box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.2), 0 1px 2px rgba(0, 0, 0, 0.05); - -webkit-transition: 0.1s linear background-image; - -moz-transition: 0.1s linear background-image; - -ms-transition: 0.1s linear background-image; - -o-transition: 0.1s linear background-image; - transition: 0.1s linear background-image; - overflow: visible; - - } - - - .ui-state-default a, .ui-state-default a:link, .ui-state-default a:visited { color: #555555; text-decoration: none; } - .ui-state-hover, .ui-widget-content .ui-state-hover, .ui-widget-header .ui-state-hover, .ui-state-focus, .ui-widget-content .ui-state-focus, .ui-widget-header .ui-state-focus { - background-position: 0 -15px; - color: #333; - text-decoration: none; - } - - .ui-state-hover a, .ui-state-hover a:hover, .ui-state-hover a:link, .ui-state-hover a:visited { color: #212121; text-decoration: none; } - .ui-state-active, .ui-widget-content .ui-state-active, .ui-widget-header .ui-state-active { border: 1px solid #aaaaaa; font-weight: normal; color: #212121; } - .ui-state-active a, .ui-state-active a:link, .ui-state-active a:visited { color: #212121; text-decoration: none; } - .ui-widget :active { outline: none; } - - /* Interaction Cues - ----------------------------------*/ - - - .ui-state-highlight p, .ui-state-error p, .ui-state-default p{ - font-size: 13px; - font-weight: normal; - line-height: 18px; - margin:7px 15px; - } - .ui-state-highlight, .ui-widget-content .ui-state-highlight, .ui-widget-header .ui-state-highlight { - - - position: relative; - margin-bottom: 18px; - color: #404040; - background-color: #eedc94; - background-repeat: repeat-x; - background-image: -khtml-gradient(linear, left top, left bottom, from(#fceec1), to(#eedc94)); - background-image: -moz-linear-gradient(top, #fceec1, #eedc94); - background-image: -ms-linear-gradient(top, #fceec1, #eedc94); - background-image: -webkit-gradient(linear, left top, left bottom, color-stop(0%, #fceec1), color-stop(100%, #eedc94)); - background-image: -webkit-linear-gradient(top, #fceec1, #eedc94); - background-image: -o-linear-gradient(top, #fceec1, #eedc94); - background-image: linear-gradient(top, #fceec1, #eedc94); - filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#fceec1', endColorstr='#eedc94', GradientType=0); - text-shadow: 0 -1px 0 rgba(0, 0, 0, 0.25); - border-color: #eedc94 #eedc94 #e4c652; - border-color: rgba(0, 0, 0, 0.1) rgba(0, 0, 0, 0.1) rgba(0, 0, 0, 0.25); - text-shadow: 0 1px 0 rgba(255, 255, 255, 0.5); - border-width: 1px; - border-style: solid; - -webkit-border-radius: 4px; - -moz-border-radius: 4px; - border-radius: 4px; - -webkit-box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.25); - -moz-box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.25); - box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.25); - - - } - .ui-state-highlight a, .ui-widget-content .ui-state-highlight a,.ui-widget-header .ui-state-highlight a { color: #363636; } - .ui-state-error, .ui-widget-content .ui-state-error, .ui-widget-header .ui-state-error { - - - position: relative; - margin-bottom: 18px; - color: #ffffff; - border-width: 1px; - border-style: solid; - -webkit-border-radius: 4px; - -moz-border-radius: 4px; - border-radius: 4px; - -webkit-box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.25); - -moz-box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.25); - box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.25); - background-color: #c43c35; - background-repeat: repeat-x; - background-image: -khtml-gradient(linear, left top, left bottom, from(#ee5f5b), to(#c43c35)); - background-image: -moz-linear-gradient(top, #ee5f5b, #c43c35); - background-image: -ms-linear-gradient(top, #ee5f5b, #c43c35); - background-image: -webkit-gradient(linear, left top, left bottom, color-stop(0%, #ee5f5b), color-stop(100%, #c43c35)); - background-image: -webkit-linear-gradient(top, #ee5f5b, #c43c35); - background-image: -o-linear-gradient(top, #ee5f5b, #c43c35); - background-image: linear-gradient(top, #ee5f5b, #c43c35); - filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ee5f5b', endColorstr='#c43c35', GradientType=0); - text-shadow: 0 -1px 0 rgba(0, 0, 0, 0.25); - border-color: #c43c35 #c43c35 #882a25; - border-color: rgba(0, 0, 0, 0.1) rgba(0, 0, 0, 0.1) rgba(0, 0, 0, 0.25); - - - } - .ui-state-error a, .ui-widget-content .ui-state-error a, .ui-widget-header .ui-state-error a { color: #cd0a0a; } - .ui-state-error-text, .ui-widget-content .ui-state-error-text, .ui-widget-header .ui-state-error-text { color: #cd0a0a; } - .ui-priority-primary, .ui-widget-content .ui-priority-primary, .ui-widget-header .ui-priority-primary { font-weight: bold; } - .ui-priority-secondary, .ui-widget-content .ui-priority-secondary, .ui-widget-header .ui-priority-secondary { opacity: .7; filter:Alpha(Opacity=70); font-weight: normal; } - .ui-state-disabled, .ui-widget-content .ui-state-disabled, .ui-widget-header .ui-state-disabled { opacity: .35; filter:Alpha(Opacity=35); background-image: none; } - .ui-state-disabled .ui-icon { filter:Alpha(Opacity=35); } /* For IE8 - See #6059 */ - - - /* Icons - ----------------------------------*/ - - /* states and images */ - .ui-icon { width: 16px; height: 16px; background-image: url(images/ui-icons_222222_256x240.png); } - .ui-widget-content .ui-icon {background-image: url(images/ui-icons_222222_256x240.png); } - .ui-widget-header .ui-icon {background-image: url(images/ui-icons_222222_256x240.png); } - .ui-state-default .ui-icon { background-image: url(images/ui-icons_888888_256x240.png); } - .ui-state-hover .ui-icon, .ui-state-focus .ui-icon {background-image: url(images/ui-icons_454545_256x240.png); } - .ui-state-active .ui-icon {background-image: url(images/ui-icons_454545_256x240.png); } - .ui-state-highlight .ui-icon {background-image: url(images/ui-icons_2e83ff_256x240.png); } - .ui-state-error .ui-icon, .ui-state-error-text .ui-icon {background-image: url(images/ui-icons_f6cf3b_256x240.png); } - - /* positioning */ - .ui-icon-carat-1-n { background-position: 0 0; } - .ui-icon-carat-1-ne { background-position: -16px 0; } - .ui-icon-carat-1-e { background-position: -32px 0; } - .ui-icon-carat-1-se { background-position: -48px 0; } - .ui-icon-carat-1-s { background-position: -64px 0; } - .ui-icon-carat-1-sw { background-position: -80px 0; } - .ui-icon-carat-1-w { background-position: -96px 0; } - .ui-icon-carat-1-nw { background-position: -112px 0; } - .ui-icon-carat-2-n-s { background-position: -128px 0; } - .ui-icon-carat-2-e-w { background-position: -144px 0; } - .ui-icon-triangle-1-n { background-position: 0 -16px; } - .ui-icon-triangle-1-ne { background-position: -16px -16px; } - .ui-icon-triangle-1-e { background-position: -32px -16px; } - .ui-icon-triangle-1-se { background-position: -48px -16px; } - .ui-icon-triangle-1-s { background-position: -64px -16px; } - .ui-icon-triangle-1-sw { background-position: -80px -16px; } - .ui-icon-triangle-1-w { background-position: -96px -16px; } - .ui-icon-triangle-1-nw { background-position: -112px -16px; } - .ui-icon-triangle-2-n-s { background-position: -128px -16px; } - .ui-icon-triangle-2-e-w { background-position: -144px -16px; } - .ui-icon-arrow-1-n { background-position: 0 -32px; } - .ui-icon-arrow-1-ne { background-position: -16px -32px; } - .ui-icon-arrow-1-e { background-position: -32px -32px; } - .ui-icon-arrow-1-se { background-position: -48px -32px; } - .ui-icon-arrow-1-s { background-position: -64px -32px; } - .ui-icon-arrow-1-sw { background-position: -80px -32px; } - .ui-icon-arrow-1-w { background-position: -96px -32px; } - .ui-icon-arrow-1-nw { background-position: -112px -32px; } - .ui-icon-arrow-2-n-s { background-position: -128px -32px; } - .ui-icon-arrow-2-ne-sw { background-position: -144px -32px; } - .ui-icon-arrow-2-e-w { background-position: -160px -32px; } - .ui-icon-arrow-2-se-nw { background-position: -176px -32px; } - .ui-icon-arrowstop-1-n { background-position: -192px -32px; } - .ui-icon-arrowstop-1-e { background-position: -208px -32px; } - .ui-icon-arrowstop-1-s { background-position: -224px -32px; } - .ui-icon-arrowstop-1-w { background-position: -240px -32px; } - .ui-icon-arrowthick-1-n { background-position: 0 -48px; } - .ui-icon-arrowthick-1-ne { background-position: -16px -48px; } - .ui-icon-arrowthick-1-e { background-position: -32px -48px; } - .ui-icon-arrowthick-1-se { background-position: -48px -48px; } - .ui-icon-arrowthick-1-s { background-position: -64px -48px; } - .ui-icon-arrowthick-1-sw { background-position: -80px -48px; } - .ui-icon-arrowthick-1-w { background-position: -96px -48px; } - .ui-icon-arrowthick-1-nw { background-position: -112px -48px; } - .ui-icon-arrowthick-2-n-s { background-position: -128px -48px; } - .ui-icon-arrowthick-2-ne-sw { background-position: -144px -48px; } - .ui-icon-arrowthick-2-e-w { background-position: -160px -48px; } - .ui-icon-arrowthick-2-se-nw { background-position: -176px -48px; } - .ui-icon-arrowthickstop-1-n { background-position: -192px -48px; } - .ui-icon-arrowthickstop-1-e { background-position: -208px -48px; } - .ui-icon-arrowthickstop-1-s { background-position: -224px -48px; } - .ui-icon-arrowthickstop-1-w { background-position: -240px -48px; } - .ui-icon-arrowreturnthick-1-w { background-position: 0 -64px; } - .ui-icon-arrowreturnthick-1-n { background-position: -16px -64px; } - .ui-icon-arrowreturnthick-1-e { background-position: -32px -64px; } - .ui-icon-arrowreturnthick-1-s { background-position: -48px -64px; } - .ui-icon-arrowreturn-1-w { background-position: -64px -64px; } - .ui-icon-arrowreturn-1-n { background-position: -80px -64px; } - .ui-icon-arrowreturn-1-e { background-position: -96px -64px; } - .ui-icon-arrowreturn-1-s { background-position: -112px -64px; } - .ui-icon-arrowrefresh-1-w { background-position: -128px -64px; } - .ui-icon-arrowrefresh-1-n { background-position: -144px -64px; } - .ui-icon-arrowrefresh-1-e { background-position: -160px -64px; } - .ui-icon-arrowrefresh-1-s { background-position: -176px -64px; } - .ui-icon-arrow-4 { background-position: 0 -80px; } - .ui-icon-arrow-4-diag { background-position: -16px -80px; } - .ui-icon-extlink { background-position: -32px -80px; } - .ui-icon-newwin { background-position: -48px -80px; } - .ui-icon-refresh { background-position: -64px -80px; } - .ui-icon-shuffle { background-position: -80px -80px; } - .ui-icon-transfer-e-w { background-position: -96px -80px; } - .ui-icon-transferthick-e-w { background-position: -112px -80px; } - .ui-icon-folder-collapsed { background-position: 0 -96px; } - .ui-icon-folder-open { background-position: -16px -96px; } - .ui-icon-document { background-position: -32px -96px; } - .ui-icon-document-b { background-position: -48px -96px; } - .ui-icon-note { background-position: -64px -96px; } - .ui-icon-mail-closed { background-position: -80px -96px; } - .ui-icon-mail-open { background-position: -96px -96px; } - .ui-icon-suitcase { background-position: -112px -96px; } - .ui-icon-comment { background-position: -128px -96px; } - .ui-icon-person { background-position: -144px -96px; } - .ui-icon-print { background-position: -160px -96px; } - .ui-icon-trash { background-position: -176px -96px; } - .ui-icon-locked { background-position: -192px -96px; } - .ui-icon-unlocked { background-position: -208px -96px; } - .ui-icon-bookmark { background-position: -224px -96px; } - .ui-icon-tag { background-position: -240px -96px; } - .ui-icon-home { background-position: 0 -112px; } - .ui-icon-flag { background-position: -16px -112px; } - .ui-icon-calendar { background-position: -32px -112px; } - .ui-icon-cart { background-position: -48px -112px; } - .ui-icon-pencil { background-position: -64px -112px; } - .ui-icon-clock { background-position: -80px -112px; } - .ui-icon-disk { background-position: -96px -112px; } - .ui-icon-calculator { background-position: -112px -112px; } - .ui-icon-zoomin { background-position: -128px -112px; } - .ui-icon-zoomout { background-position: -144px -112px; } - .ui-icon-search { background-position: -160px -112px; } - .ui-icon-wrench { background-position: -176px -112px; } - .ui-icon-gear { background-position: -192px -112px; } - .ui-icon-heart { background-position: -208px -112px; } - .ui-icon-star { background-position: -224px -112px; } - .ui-icon-link { background-position: -240px -112px; } - .ui-icon-cancel { background-position: 0 -128px; } - .ui-icon-plus { background-position: -16px -128px; } - .ui-icon-plusthick { background-position: -32px -128px; } - .ui-icon-minus { background-position: -48px -128px; } - .ui-icon-minusthick { background-position: -64px -128px; } - .ui-icon-close { background-position: -80px -128px; } - .ui-icon-closethick { background-position: -96px -128px; } - .ui-icon-key { background-position: -112px -128px; } - .ui-icon-lightbulb { background-position: -128px -128px; } - .ui-icon-scissors { background-position: -144px -128px; } - .ui-icon-clipboard { background-position: -160px -128px; } - .ui-icon-copy { background-position: -176px -128px; } - .ui-icon-contact { background-position: -192px -128px; } - .ui-icon-image { background-position: -208px -128px; } - .ui-icon-video { background-position: -224px -128px; } - .ui-icon-script { background-position: -240px -128px; } - .ui-icon-alert { background-position: 0 -144px; } - .ui-icon-info { background-position: -16px -144px; } - .ui-icon-notice { background-position: -32px -144px; } - .ui-icon-help { background-position: -48px -144px; } - .ui-icon-check { background-position: -64px -144px; } - .ui-icon-bullet { background-position: -80px -144px; } - .ui-icon-radio-off { background-position: -96px -144px; } - .ui-icon-radio-on { background-position: -112px -144px; } - .ui-icon-pin-w { background-position: -128px -144px; } - .ui-icon-pin-s { background-position: -144px -144px; } - .ui-icon-play { background-position: 0 -160px; } - .ui-icon-pause { background-position: -16px -160px; } - .ui-icon-seek-next { background-position: -32px -160px; } - .ui-icon-seek-prev { background-position: -48px -160px; } - .ui-icon-seek-end { background-position: -64px -160px; } - .ui-icon-seek-start { background-position: -80px -160px; } - /* ui-icon-seek-first is deprecated, use ui-icon-seek-start instead */ - .ui-icon-seek-first { background-position: -80px -160px; } - .ui-icon-stop { background-position: -96px -160px; } - .ui-icon-eject { background-position: -112px -160px; } - .ui-icon-volume-off { background-position: -128px -160px; } - .ui-icon-volume-on { background-position: -144px -160px; } - .ui-icon-power { background-position: 0 -176px; } - .ui-icon-signal-diag { background-position: -16px -176px; } - .ui-icon-signal { background-position: -32px -176px; } - .ui-icon-battery-0 { background-position: -48px -176px; } - .ui-icon-battery-1 { background-position: -64px -176px; } - .ui-icon-battery-2 { background-position: -80px -176px; } - .ui-icon-battery-3 { background-position: -96px -176px; } - .ui-icon-circle-plus { background-position: 0 -192px; } - .ui-icon-circle-minus { background-position: -16px -192px; } - .ui-icon-circle-close { background-position: -32px -192px; } - .ui-icon-circle-triangle-e { background-position: -48px -192px; } - .ui-icon-circle-triangle-s { background-position: -64px -192px; } - .ui-icon-circle-triangle-w { background-position: -80px -192px; } - .ui-icon-circle-triangle-n { background-position: -96px -192px; } - .ui-icon-circle-arrow-e { background-position: -112px -192px; } - .ui-icon-circle-arrow-s { background-position: -128px -192px; } - .ui-icon-circle-arrow-w { background-position: -144px -192px; } - .ui-icon-circle-arrow-n { background-position: -160px -192px; } - .ui-icon-circle-zoomin { background-position: -176px -192px; } - .ui-icon-circle-zoomout { background-position: -192px -192px; } - .ui-icon-circle-check { background-position: -208px -192px; } - .ui-icon-circlesmall-plus { background-position: 0 -208px; } - .ui-icon-circlesmall-minus { background-position: -16px -208px; } - .ui-icon-circlesmall-close { background-position: -32px -208px; } - .ui-icon-squaresmall-plus { background-position: -48px -208px; } - .ui-icon-squaresmall-minus { background-position: -64px -208px; } - .ui-icon-squaresmall-close { background-position: -80px -208px; } - .ui-icon-grip-dotted-vertical { background-position: 0 -224px; } - .ui-icon-grip-dotted-horizontal { background-position: -16px -224px; } - .ui-icon-grip-solid-vertical { background-position: -32px -224px; } - .ui-icon-grip-solid-horizontal { background-position: -48px -224px; } - .ui-icon-gripsmall-diagonal-se { background-position: -64px -224px; } - .ui-icon-grip-diagonal-se { background-position: -80px -224px; } - - - /* Misc visuals - ----------------------------------*/ - - /* Corner radius */ - .ui-corner-all, - .ui-corner-top, - .ui-corner-left, - .ui-corner-tl { - -moz-border-radius-topleft: 4px; - -webkit-border-top-left-radius: 4px; - -khtml-border-top-left-radius: 4px; - border-top-left-radius: 4px; - } - .ui-corner-all, - .ui-corner-top, - .ui-corner-right, - .ui-corner-tr { - -moz-border-radius-topright: 4px; - -webkit-border-top-right-radius: 4px; - -khtml-border-top-right-radius: 4px; - border-top-right-radius: 4px; - } - .ui-corner-all, - .ui-corner-bottom, - .ui-corner-left, - .ui-corner-bl { - -moz-border-radius-bottomleft: 4px; - -webkit-border-bottom-left-radius: 4px; - -khtml-border-bottom-left-radius: 4px; - border-bottom-left-radius: 4px; - } - .ui-corner-all, - .ui-corner-bottom, - .ui-corner-right, - .ui-corner-br { - -moz-border-radius-bottomright: 4px; - -webkit-border-bottom-right-radius: 4px; - -khtml-border-bottom-right-radius: 4px; - border-bottom-right-radius: 4px; - } - - - /* Overlays */ - - .ui-widget-overlay { - background: #aaaaaa url(images/ui-bg_flat_0_aaaaaa_40x100.png) 50% 50% repeat-x; - opacity: .30; - filter:Alpha(Opacity=30); - } - - .ui-widget-shadow { - margin: -8px 0 0 -8px; - padding: 8px; - background: #aaaaaa url(images/ui-bg_flat_0_aaaaaa_40x100.png) 50% 50% repeat-x; - opacity: .30;filter:Alpha(Opacity=30); - -moz-border-radius: 8px; - -khtml-border-radius: 8px; - -webkit-border-radius: 8px; - border-radius: 8px; - } - - /* - * jQuery UI Accordion 1.10.0 - * - * Copyright 2013, AUTHORS.txt (http://jqueryui.com/about) - * Dual licensed under the MIT or GPL Version 2 licenses. - * http://jquery.org/license - * - * http://jqueryui.com/accordion/ - */ - - /* IE/Win - Fix animation bug - #4615 */ - - .ui-accordion { - width: 100%; - } - .ui-accordion .ui-accordion-header { - cursor: pointer; - position: relative; - margin-top: 1px; - zoom: 1; - font-weight:bold; - } - .ui-accordion .ui-accordion-li-fix { - display: inline; - } - .ui-accordion .ui-accordion-header-active { - border-bottom: 0 !important; - } - .ui-accordion .ui-accordion-header a { - display: block; - font-size: 1em; - padding: .5em .5em .5em 1.7em; - } - .ui-accordion-icons .ui-accordion-header a { - padding-left: 2.2em; - } - .ui-accordion .ui-accordion-header .ui-icon { - position: absolute; - left: .5em; - top: 50%; - margin-top: -8px; - } - .ui-accordion .ui-accordion-content { - padding: 1em 2.2em; - border-top: 0; - margin-top: -2px; - position: relative; - top: 1px; - margin-bottom: 2px; - overflow: auto; - display: none; - zoom: 1; - } - .ui-accordion .ui-accordion-content-active { - display: block; - } - - - /* - * jQuery UI Button 1.10.0 - * - * Copyright 2013, AUTHORS.txt (http://jqueryui.com/about) - * Dual licensed under the MIT or GPL Version 2 licenses. - * http://jquery.org/license - * - * http://docs.jquery.com/UI/Button#theming - */ - - .ui-button { - - cursor: pointer; - display: inline-block; - background-color: #e6e6e6; - background-repeat: no-repeat; - background-image: -webkit-gradient(linear, 0 0, 0 100%, from(#ffffff), color-stop(25%, #ffffff), to(#e6e6e6)); - background-image: -webkit-linear-gradient(#ffffff, #ffffff 25%, #e6e6e6); - background-image: -moz-linear-gradient(top, #ffffff, #ffffff 25%, #e6e6e6); - background-image: -ms-linear-gradient(#ffffff, #ffffff 25%, #e6e6e6); - background-image: -o-linear-gradient(#ffffff, #ffffff 25%, #e6e6e6); - background-image: linear-gradient(#ffffff, #ffffff 25%, #e6e6e6); - filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffffff', endColorstr='#e6e6e6', GradientType=0); - padding: 5px 14px 6px; - margin: 0; - text-shadow: 0 1px 1px rgba(255, 255, 255, 0.75); - color: #333; - font-size: 13px; - line-height: normal; - border: 1px solid #ccc; - border-bottom-color: #bbb; - - -webkit-box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.2), 0 1px 2px rgba(0, 0, 0, 0.05); - -moz-box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.2), 0 1px 2px rgba(0, 0, 0, 0.05); - box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.2), 0 1px 2px rgba(0, 0, 0, 0.05); - -webkit-transition: 0.1s linear background-image; - -moz-transition: 0.1s linear background-image; - -ms-transition: 0.1s linear background-image; - -o-transition: 0.1s linear background-image; - transition: 0.1s linear background-image; - overflow: visible; - } /* the overflow property removes extra width in IE */ - - .ui-button-primary { - color: #ffffff; - background-color: #0064cd; - background-repeat: repeat-x; - background-image: -khtml-gradient(linear, left top, left bottom, from(#049cdb), to(#0064cd)); - background-image: -moz-linear-gradient(top, #049cdb, #0064cd); - background-image: -ms-linear-gradient(top, #049cdb, #0064cd); - background-image: -webkit-gradient(linear, left top, left bottom, color-stop(0%, #049cdb), color-stop(100%, #0064cd)); - background-image: -webkit-linear-gradient(top, #049cdb, #0064cd); - background-image: -o-linear-gradient(top, #049cdb, #0064cd); - background-image: linear-gradient(top, #049cdb, #0064cd); - filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#049cdb', endColorstr='#0064cd', GradientType=0); - text-shadow: 0 -1px 0 rgba(0, 0, 0, 0.25); - border-color: #0064cd #0064cd #003f81; - border-color: rgba(0, 0, 0, 0.1) rgba(0, 0, 0, 0.1) rgba(0, 0, 0, 0.25); - } - - - .ui-button-success{ - color:#ffffff; - background-color: #57a957; - background-repeat: repeat-x; - background-image: -khtml-gradient(linear, left top, left bottom, from(#62c462), to(#57a957)); - background-image: -moz-linear-gradient(top, #62c462, #57a957); - background-image: -ms-linear-gradient(top, #62c462, #57a957); - background-image: -webkit-gradient(linear, left top, left bottom, color-stop(0%, #62c462), color-stop(100%, #57a957)); - background-image: -webkit-linear-gradient(top, #62c462, #57a957); - background-image: -o-linear-gradient(top, #62c462, #57a957); - background-image: linear-gradient(top, #62c462, #57a957); - filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#62c462', endColorstr='#57a957', GradientType=0); - text-shadow: 0 -1px 0 rgba(0, 0, 0, 0.25); - border-color: #57a957 #57a957 #3d773d; - border-color: rgba(0, 0, 0, 0.1) rgba(0, 0, 0, 0.1) rgba(0, 0, 0, 0.25); - } - - .ui-button-error{ - color:#ffffff; - background-color: #c43c35; - background-repeat: repeat-x; - background-image: -khtml-gradient(linear, left top, left bottom, from(#ee5f5b), to(#c43c35)); - background-image: -moz-linear-gradient(top, #ee5f5b, #c43c35); - background-image: -ms-linear-gradient(top, #ee5f5b, #c43c35); - background-image: -webkit-gradient(linear, left top, left bottom, color-stop(0%, #ee5f5b), color-stop(100%, #c43c35)); - background-image: -webkit-linear-gradient(top, #ee5f5b, #c43c35); - background-image: -o-linear-gradient(top, #ee5f5b, #c43c35); - background-image: linear-gradient(top, #ee5f5b, #c43c35); - filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ee5f5b', endColorstr='#c43c35', GradientType=0); - text-shadow: 0 -1px 0 rgba(0, 0, 0, 0.25); - border-color: #c43c35 #c43c35 #882a25; - border-color: rgba(0, 0, 0, 0.1) rgba(0, 0, 0, 0.1) rgba(0, 0, 0, 0.25); - } - - .ui-button-icon-only { width: 2.2em; } /* to make room for the icon, a width needs to be set here */ - button.ui-button-icon-only { } /* button elements seem to need a little more width */ - .ui-button-icons-only { width: 3.4em; } - button.ui-button-icons-only { width: 3.7em; } - - /*button text element */ - - .ui-button .ui-button-text { display: block; } - .ui-button-text-only .ui-button-text { } - .ui-button-icon-only .ui-button-text, .ui-button-icons-only .ui-button-text { padding: .4em; text-indent: -9999999px; /*tempfix*/ display:none;} - .ui-button-text-icon-primary .ui-button-text, .ui-button-text-icons .ui-button-text { padding: .4em 1em .4em 2.1em; } - .ui-button-text-icon-secondary .ui-button-text, .ui-button-text-icons .ui-button-text { padding: .4em 2.1em .4em 1em; } - .ui-button-text-icons .ui-button-text { padding-left: 2.1em; padding-right: 2.1em; } - /* no icon support for input elements, provide padding by default */ - /* input.ui-button { padding: .4em 1em; } */ - - /*button icon element(s) */ - .ui-button-icon-only .ui-icon, .ui-button-text-icon-primary .ui-icon, .ui-button-text-icon-secondary .ui-icon, .ui-button-text-icons .ui-icon, .ui-button-icons-only .ui-icon { top: 50%; margin-top:-3px; margin-bottom:3px; } - .ui-button-icon-only .ui-icon { left: 50%; margin-left: -8px; } - .ui-button-text-icon-primary .ui-button-icon-primary, .ui-button-text-icons .ui-button-icon-primary, .ui-button-icons-only .ui-button-icon-primary { left: .5em; } - .ui-button-text-icon-secondary .ui-button-icon-secondary, .ui-button-text-icons .ui-button-icon-secondary, .ui-button-icons-only .ui-button-icon-secondary { right: .5em; } - .ui-button-text-icons .ui-button-icon-secondary, .ui-button-icons-only .ui-button-icon-secondary { right: .5em; } - - /*button sets*/ - - - .ui-buttonset { margin-right: 7px; } - .ui-buttonset .ui-state-active { - color: #ffffff; - background-color: #0064cd; - background-repeat: repeat-x; - background-image: -khtml-gradient(linear, left top, left bottom, from(#049cdb), to(#0064cd)); - background-image: -moz-linear-gradient(top, #049cdb, #0064cd); - background-image: -ms-linear-gradient(top, #049cdb, #0064cd); - background-image: -webkit-gradient(linear, left top, left bottom, color-stop(0%, #049cdb), color-stop(100%, #0064cd)); - background-image: -webkit-linear-gradient(top, #049cdb, #0064cd); - background-image: -o-linear-gradient(top, #049cdb, #0064cd); - background-image: linear-gradient(top, #049cdb, #0064cd); - filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#049cdb', endColorstr='#0064cd', GradientType=0); - text-shadow: 0 -1px 0 rgba(0, 0, 0, 0.25); - border-color: #0064cd #0064cd #003f81; - border-color: rgba(0, 0, 0, 0.1) rgba(0, 0, 0, 0.1) rgba(0, 0, 0, 0.25); - } - .ui-buttonset .ui-button { margin-left: 0; margin-right: 0; } - - /* workarounds */ - button.ui-button::-moz-focus-inner { border: 0; padding: 0; } /* reset extra padding in Firefox */ - - /* - * jQuery UI Datepicker 1.9.0 - * - * Copyright 2012-10-11, AUTHORS.txt (http://jqueryui.com/about) - * Dual licensed under the MIT or GPL Version 2 licenses. - * http://jquery.org/license - * - * http://jqueryui.com/datepicker/ - */ - .ui-datepicker { width: 17em; padding: .2em .2em 0; display: none; } - .ui-datepicker .ui-datepicker-header { position:relative; padding:.2em 0; border:0px; font-weight: bold; width: 100%; padding: 4px 0; background-color: #f5f5f5; color: #808080; } - .ui-datepicker .ui-datepicker-prev, .ui-datepicker .ui-datepicker-next { position:absolute; top: 2px; width: 1.8em; height: 1.8em; } - - .ui-datepicker .ui-datepicker-prev-hover, .ui-datepicker .ui-datepicker-next-hover { /*top: 1px;*/ } - .ui-datepicker .ui-datepicker-prev { left:2px; } - .ui-datepicker .ui-datepicker-next { right:2px; } - - .ui-datepicker .ui-datepicker-prev-hover { /*left:1px;*/ } - .ui-datepicker .ui-datepicker-next-hover { /*right:1px;*/ } - - .ui-datepicker .ui-datepicker-prev span, .ui-datepicker .ui-datepicker-next span { display: block; position: absolute; left: 50%; margin-left: -8px; top: 50%; margin-top: -8px; } - .ui-datepicker .ui-datepicker-title { margin: 0 2.3em; line-height: 1.8em; text-align: center; } - .ui-datepicker .ui-datepicker-title select { font-size:1em; margin:1px 0; } - .ui-datepicker select.ui-datepicker-month-year {width: 100%;} - .ui-datepicker select.ui-datepicker-month, - .ui-datepicker select.ui-datepicker-year { width: 49%;} - .ui-datepicker table {width: 100%; font-size: .9em; border-collapse: collapse; margin:0 0 .4em; } - .ui-datepicker th { padding: .7em .3em; text-align: center; font-weight: bold; border: 0; } - .ui-datepicker td { border: 0; padding: 1px; } - .ui-datepicker td span, .ui-datepicker td a { display: block; padding: .2em; text-align: right; text-decoration: none; } - .ui-datepicker .ui-datepicker-buttonpane { background-image: none; margin: .7em 0 0 0; padding:0 .2em; border-left: 0; border-right: 0; border-bottom: 0; } - .ui-datepicker .ui-datepicker-buttonpane button { float: right; margin: .5em .2em .4em; cursor: pointer; padding: .2em .6em .3em .6em; width:auto; overflow:visible; } - .ui-datepicker .ui-datepicker-buttonpane button.ui-datepicker-current { float:left; } - - /* with multiple calendars */ - .ui-datepicker.ui-datepicker-multi { width:auto; } - .ui-datepicker-multi .ui-datepicker-group { float:left; } - .ui-datepicker-multi .ui-datepicker-group table { width:95%; margin:0 auto .4em; } - .ui-datepicker-multi-2 .ui-datepicker-group { width:50%; } - .ui-datepicker-multi-3 .ui-datepicker-group { width:33.3%; } - .ui-datepicker-multi-4 .ui-datepicker-group { width:25%; } - .ui-datepicker-multi .ui-datepicker-group-last .ui-datepicker-header { border-left-width:0; } - .ui-datepicker-multi .ui-datepicker-group-middle .ui-datepicker-header { border-left-width:0; } - .ui-datepicker-multi .ui-datepicker-buttonpane { clear:left; } - .ui-datepicker-row-break { clear:both; width:100%; font-size:0em; } - - /* RTL support */ - .ui-datepicker-rtl { direction: rtl; } - .ui-datepicker-rtl .ui-datepicker-prev { right: 2px; left: auto; } - .ui-datepicker-rtl .ui-datepicker-next { left: 2px; right: auto; } - .ui-datepicker-rtl .ui-datepicker-prev:hover { right: 1px; left: auto; } - .ui-datepicker-rtl .ui-datepicker-next:hover { left: 1px; right: auto; } - .ui-datepicker-rtl .ui-datepicker-buttonpane { clear:right; } - .ui-datepicker-rtl .ui-datepicker-buttonpane button { float: left; } - .ui-datepicker-rtl .ui-datepicker-buttonpane button.ui-datepicker-current { float:right; } - .ui-datepicker-rtl .ui-datepicker-group { float:right; } - .ui-datepicker-rtl .ui-datepicker-group-last .ui-datepicker-header { border-right-width:0; border-left-width:1px; } - .ui-datepicker-rtl .ui-datepicker-group-middle .ui-datepicker-header { border-right-width:0; border-left-width:1px; } - - /* IE6 IFRAME FIX (taken from datepicker 1.5.3 */ - .ui-datepicker-cover { - display: none; /*sorry for IE5*/ - display: block; /*sorry for IE5*/ - position: absolute; /*must have*/ - z-index: -1; /*must have*/ - filter: mask(); /*must have*/ - top: -4px; /*must have*/ - left: -4px; /*must have*/ - width: 200px; /*must have*/ - height: 200px; /*must have*/ - } - - .ui-datepicker th{ - font-weight: bold; - color: gray; - } - - .ui-datepicker-today a:hover{ - background-color: #808080; - color: #ffffff; - - } - .ui-datepicker-today a{ - background-color: #BFBFBF; - cursor: pointer; - padding: 0 4px; - margin-bottom:0px; - - } - - - .ui-datepicker td a{ - margin-bottom:0px; - border:0px; - } - - .ui-datepicker td:hover{ - color: #ffffff; - } - - .ui-datepicker td .ui-state-default { - border:0px; - background:none; - margin-bottom:0px; - padding:5px; - color:gray; - text-align: center; - filter:none; - } - - - .ui-datepicker td .ui-state-active{ - background:#BFBFBF; - margin-bottom:0px; - font-size:normal; - text-shadow: 0px; - color: #ffffff; - -webkit-border-radius: 4px; - -moz-border-radius: 4px; - border-radius: 4px; - } - - .ui-datepicker td .ui-state-hover { - color: #ffffff; - background: #0064cd; - background-color: #0064cd; - background-repeat: repeat-x; - background-image: -khtml-gradient(linear, left top, left bottom, from(#049cdb), to(#0064cd)); - background-image: -moz-linear-gradient(top, #049cdb, #0064cd); - background-image: -ms-linear-gradient(top, #049cdb, #0064cd); - background-image: -webkit-gradient(linear, left top, left bottom, color-stop(0%, #049cdb), color-stop(100%, #0064cd)); - background-image: -webkit-linear-gradient(top, #049cdb, #0064cd); - background-image: -o-linear-gradient(top, #049cdb, #0064cd); - background-image: linear-gradient(top, #049cdb, #0064cd); - filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#049cdb', endColorstr='#0064cd', GradientType=0); - text-shadow: 0 -1px 0 rgba(0, 0, 0, 0.25); - border-color: #0064cd #0064cd #003f81; - border-color: rgba(0, 0, 0, 0.1) rgba(0, 0, 0, 0.1) rgba(0, 0, 0, 0.25); - -webkit-border-radius: 4px; - -moz-border-radius: 4px; - -khtml-border-radius: 4px; - border-radius: 4px; - } - - .ui-widget-content { - border: 1px solid #dfdfdf; - } - .ui-datepicker table { background: #fff; } - - .placeholder { - background:#f9f9f9 !important; - border: 1px dashed #bbb !important; - } - -} - -.wp-customizer { - #ui-datepicker-div { - z-index: 999999 !important; - } -} \ No newline at end of file diff --git a/library/admin/ReduxCore/assets/css/vendor/qtip/jquery.qtip.css b/library/admin/ReduxCore/assets/css/vendor/qtip/jquery.qtip.css deleted file mode 100644 index 99afc5c5..00000000 --- a/library/admin/ReduxCore/assets/css/vendor/qtip/jquery.qtip.css +++ /dev/null @@ -1,624 +0,0 @@ -/* - * qTip2 - Pretty powerful tooltips - v2.2.0 - * http://qtip2.com - * - * Copyright (c) 2013 Craig Michael Thompson - * Released under the MIT, GPL licenses - * http://jquery.org/license - * - * Date: Thu Nov 21 2013 08:34 GMT+0000 - * Plugins: tips modal viewport svg imagemap ie6 - * Styles: basic css3 - */ -.qtip{ - position: absolute; - left: -28000px; - top: -28000px; - display: none; - - max-width: 280px; - min-width: 50px; - - font-size: 10.5px; - line-height: 12px; - - direction: ltr; - - box-shadow: none; - padding: 0; -} - - .qtip-content{ - position: relative; - padding: 5px 9px; - overflow: hidden; - - text-align: left; - word-wrap: break-word; - } - - .qtip-titlebar{ - position: relative; - padding: 5px 35px 5px 10px; - overflow: hidden; - - border-width: 0 0 1px; - font-weight: bold; - } - - .qtip-titlebar + .qtip-content{ border-top-width: 0 !important; } - - /* Default close button class */ - .qtip-close{ - position: absolute; - right: -9px; top: -9px; - - cursor: pointer; - outline: medium none; - - border-width: 1px; - border-style: solid; - border-color: transparent; - } - - .qtip-titlebar .qtip-close{ - right: 4px; top: 50%; - margin-top: -9px; - } - - * html .qtip-titlebar .qtip-close{ top: 16px; } /* IE fix */ - - .qtip-titlebar .ui-icon, - .qtip-icon .ui-icon{ - display: block; - text-indent: -1000em; - direction: ltr; - } - - .qtip-icon, .qtip-icon .ui-icon{ - -moz-border-radius: 3px; - -webkit-border-radius: 3px; - border-radius: 3px; - text-decoration: none; - } - - .qtip-icon .ui-icon{ - width: 18px; - height: 14px; - - line-height: 14px; - text-align: center; - text-indent: 0; - font: normal bold 10px/13px Tahoma,sans-serif; - - color: inherit; - background: transparent none no-repeat -100em -100em; - } - -/* Applied to 'focused' tooltips e.g. most recently displayed/interacted with */ -.qtip-focus{} - -/* Applied on hover of tooltips i.e. added/removed on mouseenter/mouseleave respectively */ -.qtip-hover{} - -/* Default tooltip style */ -.qtip-default{ - border-width: 1px; - border-style: solid; - border-color: black; -/* #F1D031;*/ - - background-color: #FFFFA3; - color: #555; -} - - .qtip-default .qtip-titlebar{ - background-color: #FFEF93; - } - - .qtip-default .qtip-icon{ - border-color: #CCC; - background: #F1F1F1; - color: #777; - } - - .qtip-default .qtip-titlebar .qtip-close{ - border-color: #AAA; - color: #111; - } - - - -/*! Light tooltip style */ -.qtip-light{ - background-color: white; - border-color: #E2E2E2; - color: #454545; -} - - .qtip-light .qtip-titlebar{ - background-color: #f1f1f1; - } - - -/*! Dark tooltip style */ -.qtip-dark{ - background-color: #505050; - border-color: #303030; - color: #f3f3f3; -} - - .qtip-dark .qtip-titlebar{ - background-color: #404040; - } - - .qtip-dark .qtip-icon{ - border-color: #444; - } - - .qtip-dark .qtip-titlebar .ui-state-hover{ - border-color: #303030; - } - - -/*! Cream tooltip style */ -.qtip-cream{ - background-color: #FBF7AA; - border-color: #F9E98E; - color: #A27D35; -} - - .qtip-cream .qtip-titlebar{ - background-color: #F0DE7D; - } - - .qtip-cream .qtip-close .qtip-icon{ - background-position: -82px 0; - } - - -/*! Red tooltip style */ -.qtip-red{ - background-color: #F78B83; - border-color: #D95252; - color: #912323; -} - - .qtip-red .qtip-titlebar{ - background-color: #F06D65; - } - - .qtip-red .qtip-close .qtip-icon{ - background-position: -102px 0; - } - - .qtip-red .qtip-icon{ - border-color: #D95252; - } - - .qtip-red .qtip-titlebar .ui-state-hover{ - border-color: #D95252; - } - - -/*! Green tooltip style */ -.qtip-green{ - background-color: #CAED9E; - border-color: #90D93F; - color: #3F6219; -} - - .qtip-green .qtip-titlebar{ - background-color: #B0DE78; - } - - .qtip-green .qtip-close .qtip-icon{ - background-position: -42px 0; - } - - -/*! Blue tooltip style */ -.qtip-blue{ - background-color: #E5F6FE; - border-color: #ADD9ED; - color: #5E99BD; -} - - .qtip-blue .qtip-titlebar{ - background-color: #D0E9F5; - } - - .qtip-blue .qtip-close .qtip-icon{ - background-position: -2px 0; - } - - - -.qtip-shadow{ - -webkit-box-shadow: 1px 1px 3px 1px rgba(0, 0, 0, 0.15); - -moz-box-shadow: 1px 1px 3px 1px rgba(0, 0, 0, 0.15); - box-shadow: 1px 1px 3px 1px rgba(0, 0, 0, 0.15); -} - -/* Add rounded corners to your tooltips in: FF3+, Chrome 2+, Opera 10.6+, IE9+, Safari 2+ */ -.qtip-rounded, -.qtip-tipsy, -.qtip-bootstrap{ - -moz-border-radius: 5px; - -webkit-border-radius: 5px; - border-radius: 5px; -} - -.qtip-rounded .qtip-titlebar{ - -moz-border-radius: 4px 4px 0 0; - -webkit-border-radius: 4px 4px 0 0; - border-radius: 4px 4px 0 0; -} - -/* Youtube tooltip style */ -.qtip-youtube{ - -moz-border-radius: 2px; - -webkit-border-radius: 2px; - border-radius: 2px; - - -webkit-box-shadow: 0 0 3px #333; - -moz-box-shadow: 0 0 3px #333; - box-shadow: 0 0 3px #333; - - color: white; - border-width: 0; - - background: #4A4A4A; - background-image: -webkit-gradient(linear,left top,left bottom,color-stop(0,#4A4A4A),color-stop(100%,black)); - background-image: -webkit-linear-gradient(top,#4A4A4A 0,black 100%); - background-image: -moz-linear-gradient(top,#4A4A4A 0,black 100%); - background-image: -ms-linear-gradient(top,#4A4A4A 0,black 100%); - background-image: -o-linear-gradient(top,#4A4A4A 0,black 100%); -} - - .qtip-youtube .qtip-titlebar{ - background-color: #4A4A4A; - background-color: rgba(0,0,0,0); - } - - .qtip-youtube .qtip-content{ - padding: .75em; - font: 12px arial,sans-serif; - - filter: progid:DXImageTransform.Microsoft.Gradient(GradientType=0,StartColorStr=#4a4a4a,EndColorStr=#000000); - -ms-filter: "progid:DXImageTransform.Microsoft.Gradient(GradientType=0,StartColorStr=#4a4a4a,EndColorStr=#000000);"; - } - - .qtip-youtube .qtip-icon{ - border-color: #222; - } - - .qtip-youtube .qtip-titlebar .ui-state-hover{ - border-color: #303030; - } - - -/* jQuery TOOLS Tooltip style */ -.qtip-jtools{ - background: #232323; - background: rgba(0, 0, 0, 0.7); - background-image: -webkit-gradient(linear, left top, left bottom, from(#717171), to(#232323)); - background-image: -moz-linear-gradient(top, #717171, #232323); - background-image: -webkit-linear-gradient(top, #717171, #232323); - background-image: -ms-linear-gradient(top, #717171, #232323); - background-image: -o-linear-gradient(top, #717171, #232323); - - border: 2px solid #ddd; - border: 2px solid rgba(241,241,241,1); - - -moz-border-radius: 2px; - -webkit-border-radius: 2px; - border-radius: 2px; - - -webkit-box-shadow: 0 0 12px #333; - -moz-box-shadow: 0 0 12px #333; - box-shadow: 0 0 12px #333; -} - - /* IE Specific */ - .qtip-jtools .qtip-titlebar{ - background-color: transparent; - filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=#717171,endColorstr=#4A4A4A); - -ms-filter: "progid:DXImageTransform.Microsoft.gradient(startColorstr=#717171,endColorstr=#4A4A4A)"; - } - .qtip-jtools .qtip-content{ - filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=#4A4A4A,endColorstr=#232323); - -ms-filter: "progid:DXImageTransform.Microsoft.gradient(startColorstr=#4A4A4A,endColorstr=#232323)"; - } - - .qtip-jtools .qtip-titlebar, - .qtip-jtools .qtip-content{ - background: transparent; - color: white; - border: 0 dashed transparent; - } - - .qtip-jtools .qtip-icon{ - border-color: #555; - } - - .qtip-jtools .qtip-titlebar .ui-state-hover{ - border-color: #333; - } - - -/* Cluetip style */ -.qtip-cluetip{ - -webkit-box-shadow: 4px 4px 5px rgba(0, 0, 0, 0.4); - -moz-box-shadow: 4px 4px 5px rgba(0, 0, 0, 0.4); - box-shadow: 4px 4px 5px rgba(0, 0, 0, 0.4); - - background-color: #D9D9C2; - color: #111; - border: 0 dashed transparent; -} - - .qtip-cluetip .qtip-titlebar{ - background-color: #87876A; - color: white; - border: 0 dashed transparent; - } - - .qtip-cluetip .qtip-icon{ - border-color: #808064; - } - - .qtip-cluetip .qtip-titlebar .ui-state-hover{ - border-color: #696952; - color: #696952; - } - - -/* Tipsy style */ -.qtip-tipsy{ - background: black; - background: rgba(0, 0, 0, .87); - - color: white; - border: 0 solid transparent; - - font-size: 11px; - font-family: 'Lucida Grande', sans-serif; - font-weight: bold; - line-height: 16px; - text-shadow: 0 1px black; -} - - .qtip-tipsy .qtip-titlebar{ - padding: 6px 35px 0 10px; - background-color: transparent; - } - - .qtip-tipsy .qtip-content{ - padding: 6px 10px; - } - - .qtip-tipsy .qtip-icon{ - border-color: #222; - text-shadow: none; - } - - .qtip-tipsy .qtip-titlebar .ui-state-hover{ - border-color: #303030; - } - - -/* Tipped style */ -.qtip-tipped{ - border: 3px solid #959FA9; - - -moz-border-radius: 3px; - -webkit-border-radius: 3px; - border-radius: 3px; - - background-color: #F9F9F9; - color: #454545; - - font-weight: normal; - font-family: serif; -} - - .qtip-tipped .qtip-titlebar{ - border-bottom-width: 0; - - color: white; - background: #3A79B8; - background-image: -webkit-gradient(linear, left top, left bottom, from(#3A79B8), to(#2E629D)); - background-image: -webkit-linear-gradient(top, #3A79B8, #2E629D); - background-image: -moz-linear-gradient(top, #3A79B8, #2E629D); - background-image: -ms-linear-gradient(top, #3A79B8, #2E629D); - background-image: -o-linear-gradient(top, #3A79B8, #2E629D); - filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=#3A79B8,endColorstr=#2E629D); - -ms-filter: "progid:DXImageTransform.Microsoft.gradient(startColorstr=#3A79B8,endColorstr=#2E629D)"; - } - - .qtip-tipped .qtip-icon{ - border: 2px solid #285589; - background: #285589; - } - - .qtip-tipped .qtip-icon .ui-icon{ - background-color: #FBFBFB; - color: #555; - } - - -/** - * Twitter Bootstrap style. - * - * Tested with IE 8, IE 9, Chrome 18, Firefox 9, Opera 11. - * Does not work with IE 7. - */ -.qtip-bootstrap{ - /** Taken from Bootstrap body */ - font-size: 14px; - line-height: 20px; - color: #333333; - - /** Taken from Bootstrap .popover */ - padding: 1px; - background-color: #ffffff; - border: 1px solid #ccc; - border: 1px solid rgba(0, 0, 0, 0.2); - -webkit-border-radius: 6px; - -moz-border-radius: 6px; - border-radius: 6px; - -webkit-box-shadow: 0 5px 10px rgba(0, 0, 0, 0.2); - -moz-box-shadow: 0 5px 10px rgba(0, 0, 0, 0.2); - box-shadow: 0 5px 10px rgba(0, 0, 0, 0.2); - -webkit-background-clip: padding-box; - -moz-background-clip: padding; - background-clip: padding-box; -} - - .qtip-bootstrap .qtip-titlebar{ - /** Taken from Bootstrap .popover-title */ - padding: 8px 14px; - margin: 0; - font-size: 14px; - font-weight: normal; - line-height: 18px; - background-color: #f7f7f7; - border-bottom: 1px solid #ebebeb; - -webkit-border-radius: 5px 5px 0 0; - -moz-border-radius: 5px 5px 0 0; - border-radius: 5px 5px 0 0; - } - - .qtip-bootstrap .qtip-titlebar .qtip-close{ - /** - * Overrides qTip2: - * .qtip-titlebar .qtip-close{ - * [...] - * right: 4px; - * top: 50%; - * [...] - * border-style: solid; - * } - */ - right: 11px; - top: 45%; - border-style: none; - } - - .qtip-bootstrap .qtip-content{ - /** Taken from Bootstrap .popover-content */ - padding: 9px 14px; - } - - .qtip-bootstrap .qtip-icon{ - /** - * Overrides qTip2: - * .qtip-default .qtip-icon { - * border-color: #CCC; - * background: #F1F1F1; - * color: #777; - * } - */ - background: transparent; - } - - .qtip-bootstrap .qtip-icon .ui-icon{ - /** - * Overrides qTip2: - * .qtip-icon .ui-icon{ - * width: 18px; - * height: 14px; - * } - */ - width: auto; - height: auto; - - /* Taken from Bootstrap .close */ - float: right; - font-size: 20px; - font-weight: bold; - line-height: 18px; - color: #000000; - text-shadow: 0 1px 0 #ffffff; - opacity: 0.2; - filter: alpha(opacity=20); - } - - .qtip-bootstrap .qtip-icon .ui-icon:hover{ - /* Taken from Bootstrap .close:hover */ - color: #000000; - text-decoration: none; - cursor: pointer; - opacity: 0.4; - filter: alpha(opacity=40); - } - - -/* IE9 fix - removes all filters */ -.qtip:not(.ie9haxors) div.qtip-content, -.qtip:not(.ie9haxors) div.qtip-titlebar{ - filter: none; - -ms-filter: none; -} - - - -.qtip .qtip-tip{ - margin: 0 auto; - overflow: hidden; - z-index: 10; - -} - - /* Opera bug #357 - Incorrect tip position - https://github.com/Craga89/qTip2/issues/367 */ - x:-o-prefocus, .qtip .qtip-tip{ - visibility: hidden; - } - - .qtip .qtip-tip, - .qtip .qtip-tip .qtip-vml, - .qtip .qtip-tip canvas{ - position: absolute; - - color: #123456; - background: transparent; - border: 0 dashed transparent; - } - - .qtip .qtip-tip canvas{ top: 0; left: 0; } - - .qtip .qtip-tip .qtip-vml{ - behavior: url(#default#VML); - display: inline-block; - visibility: visible; - } - -#qtip-overlay{ - position: fixed; - left: 0; top: 0; - width: 100%; height: 100%; -} - - /* Applied to modals with show.modal.blur set to true */ - #qtip-overlay.blurs{ cursor: pointer; } - - /* Change opacity of overlay here */ - #qtip-overlay div{ - position: absolute; - left: 0; top: 0; - width: 100%; height: 100%; - - background-color: black; - - opacity: 0.7; - filter:alpha(opacity=70); - -ms-filter:"progid:DXImageTransform.Microsoft.Alpha(Opacity=70)"; - } - - - -.qtipmodal-ie6fix{ - position: absolute !important; -} \ No newline at end of file diff --git a/library/admin/ReduxCore/assets/css/vendor/qtip/jquery.qtip.min.css b/library/admin/ReduxCore/assets/css/vendor/qtip/jquery.qtip.min.css deleted file mode 100644 index 0bedfc3f..00000000 --- a/library/admin/ReduxCore/assets/css/vendor/qtip/jquery.qtip.min.css +++ /dev/null @@ -1,2 +0,0 @@ - -.qtip{position:absolute;left:-28000px;top:-28000px;display:none;max-width:280px;min-width:50px;font-size:10.5px;line-height:12px;direction:ltr;box-shadow:none;padding:0}.qtip-content{position:relative;padding:5px 9px;overflow:hidden;text-align:left;word-wrap:break-word}.qtip-titlebar{position:relative;padding:5px 35px 5px 10px;overflow:hidden;border-width:0 0 1px;font-weight:bold}.qtip-titlebar+.qtip-content{border-top-width:0!important}.qtip-close{position:absolute;right:-9px;top:-9px;cursor:pointer;outline:medium none;border-width:1px;border-style:solid;border-color:transparent}.qtip-titlebar .qtip-close{right:4px;top:50%;margin-top:-9px}* html .qtip-titlebar .qtip-close{top:16px}.qtip-titlebar .ui-icon,.qtip-icon .ui-icon{display:block;text-indent:-1000em;direction:ltr}.qtip-icon,.qtip-icon .ui-icon{-moz-border-radius:3px;-webkit-border-radius:3px;border-radius:3px;text-decoration:none}.qtip-icon .ui-icon{width:18px;height:14px;line-height:14px;text-align:center;text-indent:0;font:normal bold 10px/13px Tahoma,sans-serif;color:inherit;background:transparent none no-repeat -100em -100em}.qtip-default{border-width:1px;border-style:solid;border-color:black;background-color:#ffffa3;color:#555}.qtip-default .qtip-titlebar{background-color:#ffef93}.qtip-default .qtip-icon{border-color:#CCC;background:#f1f1f1;color:#777}.qtip-default .qtip-titlebar .qtip-close{border-color:#AAA;color:#111}/*! Light tooltip style */.qtip-light{background-color:white;border-color:#e2e2e2;color:#454545}.qtip-light .qtip-titlebar{background-color:#f1f1f1}/*! Dark tooltip style */.qtip-dark{background-color:#505050;border-color:#303030;color:#f3f3f3}.qtip-dark .qtip-titlebar{background-color:#404040}.qtip-dark .qtip-icon{border-color:#444}.qtip-dark .qtip-titlebar .ui-state-hover{border-color:#303030}/*! Cream tooltip style */.qtip-cream{background-color:#fbf7aa;border-color:#f9e98e;color:#a27d35}.qtip-cream .qtip-titlebar{background-color:#f0de7d}.qtip-cream .qtip-close .qtip-icon{background-position:-82px 0}/*! Red tooltip style */.qtip-red{background-color:#f78b83;border-color:#d95252;color:#912323}.qtip-red .qtip-titlebar{background-color:#f06d65}.qtip-red .qtip-close .qtip-icon{background-position:-102px 0}.qtip-red .qtip-icon{border-color:#d95252}.qtip-red .qtip-titlebar .ui-state-hover{border-color:#d95252}/*! Green tooltip style */.qtip-green{background-color:#caed9e;border-color:#90d93f;color:#3f6219}.qtip-green .qtip-titlebar{background-color:#b0de78}.qtip-green .qtip-close .qtip-icon{background-position:-42px 0}/*! Blue tooltip style */.qtip-blue{background-color:#e5f6fe;border-color:#add9ed;color:#5e99bd}.qtip-blue .qtip-titlebar{background-color:#d0e9f5}.qtip-blue .qtip-close .qtip-icon{background-position:-2px 0}.qtip-shadow{-webkit-box-shadow:1px 1px 3px 1px rgba(0,0,0,0.15);-moz-box-shadow:1px 1px 3px 1px rgba(0,0,0,0.15);box-shadow:1px 1px 3px 1px rgba(0,0,0,0.15)}.qtip-rounded,.qtip-tipsy,.qtip-bootstrap{-moz-border-radius:5px;-webkit-border-radius:5px;border-radius:5px}.qtip-rounded .qtip-titlebar{-moz-border-radius:4px 4px 0 0;-webkit-border-radius:4px 4px 0 0;border-radius:4px 4px 0 0}.qtip-youtube{-moz-border-radius:2px;-webkit-border-radius:2px;border-radius:2px;-webkit-box-shadow:0 0 3px #333;-moz-box-shadow:0 0 3px #333;box-shadow:0 0 3px #333;color:white;border-width:0;background:#4a4a4a;background-image:-webkit-gradient(linear,left top,left bottom,color-stop(0,#4a4a4a),color-stop(100%,black));background-image:-webkit-linear-gradient(top,#4a4a4a 0,black 100%);background-image:-moz-linear-gradient(top,#4a4a4a 0,black 100%);background-image:-ms-linear-gradient(top,#4a4a4a 0,black 100%);background-image:-o-linear-gradient(top,#4a4a4a 0,black 100%)}.qtip-youtube .qtip-titlebar{background-color:#4a4a4a;background-color:rgba(0,0,0,0)}.qtip-youtube .qtip-content{padding:.75em;font:12px arial,sans-serif;filter:progid:DXImageTransform.Microsoft.Gradient(GradientType=0,StartColorStr=#4a4a4a,EndColorStr=#000000);-ms-filter:"progid:DXImageTransform.Microsoft.Gradient(GradientType=0,StartColorStr=#4a4a4a,EndColorStr=#000000);"}.qtip-youtube .qtip-icon{border-color:#222}.qtip-youtube .qtip-titlebar .ui-state-hover{border-color:#303030}.qtip-jtools{background:#232323;background:rgba(0,0,0,0.7);background-image:-webkit-gradient(linear,left top,left bottom,from(#717171),to(#232323));background-image:-moz-linear-gradient(top,#717171,#232323);background-image:-webkit-linear-gradient(top,#717171,#232323);background-image:-ms-linear-gradient(top,#717171,#232323);background-image:-o-linear-gradient(top,#717171,#232323);border:2px solid #ddd;border:2px solid rgba(241,241,241,1);-moz-border-radius:2px;-webkit-border-radius:2px;border-radius:2px;-webkit-box-shadow:0 0 12px #333;-moz-box-shadow:0 0 12px #333;box-shadow:0 0 12px #333}.qtip-jtools .qtip-titlebar{background-color:transparent;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=#717171,endColorstr=#4A4A4A);-ms-filter:"progid:DXImageTransform.Microsoft.gradient(startColorstr=#717171,endColorstr=#4A4A4A)"}.qtip-jtools .qtip-content{filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=#4A4A4A,endColorstr=#232323);-ms-filter:"progid:DXImageTransform.Microsoft.gradient(startColorstr=#4A4A4A,endColorstr=#232323)"}.qtip-jtools .qtip-titlebar,.qtip-jtools .qtip-content{background:transparent;color:white;border:0 dashed transparent}.qtip-jtools .qtip-icon{border-color:#555}.qtip-jtools .qtip-titlebar .ui-state-hover{border-color:#333}.qtip-cluetip{-webkit-box-shadow:4px 4px 5px rgba(0,0,0,0.4);-moz-box-shadow:4px 4px 5px rgba(0,0,0,0.4);box-shadow:4px 4px 5px rgba(0,0,0,0.4);background-color:#d9d9c2;color:#111;border:0 dashed transparent}.qtip-cluetip .qtip-titlebar{background-color:#87876a;color:white;border:0 dashed transparent}.qtip-cluetip .qtip-icon{border-color:#808064}.qtip-cluetip .qtip-titlebar .ui-state-hover{border-color:#696952;color:#696952}.qtip-tipsy{background:black;background:rgba(0,0,0,.87);color:white;border:0 solid transparent;font-size:11px;font-family:'Lucida Grande',sans-serif;font-weight:bold;line-height:16px;text-shadow:0 1px black}.qtip-tipsy .qtip-titlebar{padding:6px 35px 0 10px;background-color:transparent}.qtip-tipsy .qtip-content{padding:6px 10px}.qtip-tipsy .qtip-icon{border-color:#222;text-shadow:none}.qtip-tipsy .qtip-titlebar .ui-state-hover{border-color:#303030}.qtip-tipped{border:3px solid #959fa9;-moz-border-radius:3px;-webkit-border-radius:3px;border-radius:3px;background-color:#f9f9f9;color:#454545;font-weight:normal;font-family:serif}.qtip-tipped .qtip-titlebar{border-bottom-width:0;color:white;background:#3a79b8;background-image:-webkit-gradient(linear,left top,left bottom,from(#3a79b8),to(#2e629d));background-image:-webkit-linear-gradient(top,#3a79b8,#2e629d);background-image:-moz-linear-gradient(top,#3a79b8,#2e629d);background-image:-ms-linear-gradient(top,#3a79b8,#2e629d);background-image:-o-linear-gradient(top,#3a79b8,#2e629d);filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=#3A79B8,endColorstr=#2E629D);-ms-filter:"progid:DXImageTransform.Microsoft.gradient(startColorstr=#3A79B8,endColorstr=#2E629D)"}.qtip-tipped .qtip-icon{border:2px solid #285589;background:#285589}.qtip-tipped .qtip-icon .ui-icon{background-color:#fbfbfb;color:#555}.qtip-bootstrap{font-size:14px;line-height:20px;color:#333;padding:1px;background-color:#fff;border:1px solid #ccc;border:1px solid rgba(0,0,0,0.2);-webkit-border-radius:6px;-moz-border-radius:6px;border-radius:6px;-webkit-box-shadow:0 5px 10px rgba(0,0,0,0.2);-moz-box-shadow:0 5px 10px rgba(0,0,0,0.2);box-shadow:0 5px 10px rgba(0,0,0,0.2);-webkit-background-clip:padding-box;-moz-background-clip:padding;background-clip:padding-box}.qtip-bootstrap .qtip-titlebar{padding:8px 14px;margin:0;font-size:14px;font-weight:normal;line-height:18px;background-color:#f7f7f7;border-bottom:1px solid #ebebeb;-webkit-border-radius:5px 5px 0 0;-moz-border-radius:5px 5px 0 0;border-radius:5px 5px 0 0}.qtip-bootstrap .qtip-titlebar .qtip-close{right:11px;top:45%;border-style:none}.qtip-bootstrap .qtip-content{padding:9px 14px}.qtip-bootstrap .qtip-icon{background:transparent}.qtip-bootstrap .qtip-icon .ui-icon{width:auto;height:auto;float:right;font-size:20px;font-weight:bold;line-height:18px;color:#000;text-shadow:0 1px 0 #fff;opacity:.2;filter:alpha(opacity=20)}.qtip-bootstrap .qtip-icon .ui-icon:hover{color:#000;text-decoration:none;cursor:pointer;opacity:.4;filter:alpha(opacity=40)}.qtip:not(.ie9haxors) div.qtip-content,.qtip:not(.ie9haxors) div.qtip-titlebar{filter:none;-ms-filter:none}.qtip .qtip-tip{margin:0 auto;overflow:hidden;z-index:10}x:-o-prefocus,.qtip .qtip-tip{visibility:hidden}.qtip .qtip-tip,.qtip .qtip-tip .qtip-vml,.qtip .qtip-tip canvas{position:absolute;color:#123456;background:transparent;border:0 dashed transparent}.qtip .qtip-tip canvas{top:0;left:0}.qtip .qtip-tip .qtip-vml{behavior:url(#default#VML);display:inline-block;visibility:visible}#qtip-overlay{position:fixed;left:0;top:0;width:100%;height:100%}#qtip-overlay.blurs{cursor:pointer}#qtip-overlay div{position:absolute;left:0;top:0;width:100%;height:100%;background-color:black;opacity:.7;filter:alpha(opacity=70);-ms-filter:"alpha(opacity=70)"}.qtipmodal-ie6fix{position:absolute!important} \ No newline at end of file diff --git a/library/admin/ReduxCore/assets/css/vendor/spectrum/redux-spectrum.css b/library/admin/ReduxCore/assets/css/vendor/spectrum/redux-spectrum.css deleted file mode 100644 index 876c486b..00000000 --- a/library/admin/ReduxCore/assets/css/vendor/spectrum/redux-spectrum.css +++ /dev/null @@ -1,507 +0,0 @@ -/*** -Spectrum Colorpicker v1.5.1 -https://github.com/bgrins/spectrum -Author: Brian Grinstead -License: MIT -***/ - -.sp-container { - position:absolute; - top:0; - left:0; - display:inline-block; - *display: inline; - *zoom: 1; - /* https://github.com/bgrins/spectrum/issues/40 */ - z-index: 9999994; - overflow: hidden; -} -.sp-container.sp-flat { - position: relative; -} - -/* Fix for * { box-sizing: border-box; } */ -.sp-container, -.sp-container * { - -webkit-box-sizing: content-box; - -moz-box-sizing: content-box; - box-sizing: content-box; -} - -/* http://ansciath.tumblr.com/post/7347495869/css-aspect-ratio */ -.sp-top { - position:relative; - width: 100%; - display:inline-block; -} -.sp-top-inner { - position:absolute; - top:0; - left:0; - bottom:0; - right:0; -} -.sp-color { - position: absolute; - top:0; - left:0; - bottom:0; - right:20%; -} -.sp-hue { - position: absolute; - top:0; - right:0; - bottom:0; - left:84%; - height: 100%; -} - -.sp-clear-enabled .sp-hue { - top:33px; - height: 77.5%; -} - -.sp-fill { - padding-top: 80%; -} -.sp-sat, .sp-val { - position: absolute; - top:0; - left:0; - right:0; - bottom:0; -} - -.sp-alpha-enabled .sp-top { - margin-bottom: 18px; -} -.sp-alpha-enabled .sp-alpha { - display: block; -} -.sp-alpha-handle { - position:absolute; - top:-4px; - bottom: -4px; - width: 6px; - left: 50%; - cursor: pointer; - border: 1px solid black; - background: white; - opacity: .8; -} -.sp-alpha { - display: none; - position: absolute; - bottom: -14px; - right: 0; - left: 0; - height: 8px; -} -.sp-alpha-inner { - border: solid 1px #333; -} - -.sp-clear { - display: none; -} - -.sp-clear.sp-clear-display { - background-position: center; -} - -.sp-clear-enabled .sp-clear { - display: block; - position:absolute; - top:0px; - right:0; - bottom:0; - left:84%; - height: 28px; -} - -/* Don't allow text selection */ -.sp-container, .sp-replacer, .sp-preview, .sp-dragger, .sp-slider, .sp-alpha, .sp-clear, .sp-alpha-handle, .sp-container.sp-dragging .sp-input, .sp-container button { - -webkit-user-select:none; - -moz-user-select: -moz-none; - -o-user-select:none; - user-select: none; -} - -.sp-container.sp-input-disabled .sp-input-container { - display: none; -} -.sp-container.sp-buttons-disabled .sp-button-container { - display: none; -} -.sp-container.sp-palette-buttons-disabled .sp-palette-button-container { - display: none; -} -.sp-palette-only .sp-picker-container { - display: none; -} -.sp-palette-disabled .sp-palette-container { - display: none; -} - -.sp-initial-disabled .sp-initial { - display: none; -} - - -/* Gradients for hue, saturation and value instead of images. Not pretty... but it works */ -.sp-sat { - background-image: -webkit-gradient(linear, 0 0, 100% 0, from(#FFF), to(rgba(204, 154, 129, 0))); - background-image: -webkit-linear-gradient(left, #FFF, rgba(204, 154, 129, 0)); - background-image: -moz-linear-gradient(left, #fff, rgba(204, 154, 129, 0)); - background-image: -o-linear-gradient(left, #fff, rgba(204, 154, 129, 0)); - background-image: -ms-linear-gradient(left, #fff, rgba(204, 154, 129, 0)); - background-image: linear-gradient(to right, #fff, rgba(204, 154, 129, 0)); - -ms-filter: "progid:DXImageTransform.Microsoft.gradient(GradientType = 1, startColorstr=#FFFFFFFF, endColorstr=#00CC9A81)"; - filter : progid:DXImageTransform.Microsoft.gradient(GradientType = 1, startColorstr='#FFFFFFFF', endColorstr='#00CC9A81'); -} -.sp-val { - background-image: -webkit-gradient(linear, 0 100%, 0 0, from(#000000), to(rgba(204, 154, 129, 0))); - background-image: -webkit-linear-gradient(bottom, #000000, rgba(204, 154, 129, 0)); - background-image: -moz-linear-gradient(bottom, #000, rgba(204, 154, 129, 0)); - background-image: -o-linear-gradient(bottom, #000, rgba(204, 154, 129, 0)); - background-image: -ms-linear-gradient(bottom, #000, rgba(204, 154, 129, 0)); - background-image: linear-gradient(to top, #000, rgba(204, 154, 129, 0)); - -ms-filter: "progid:DXImageTransform.Microsoft.gradient(startColorstr=#00CC9A81, endColorstr=#FF000000)"; - filter : progid:DXImageTransform.Microsoft.gradient(startColorstr='#00CC9A81', endColorstr='#FF000000'); -} - -.sp-hue { - background: -moz-linear-gradient(top, #ff0000 0%, #ffff00 17%, #00ff00 33%, #00ffff 50%, #0000ff 67%, #ff00ff 83%, #ff0000 100%); - background: -ms-linear-gradient(top, #ff0000 0%, #ffff00 17%, #00ff00 33%, #00ffff 50%, #0000ff 67%, #ff00ff 83%, #ff0000 100%); - background: -o-linear-gradient(top, #ff0000 0%, #ffff00 17%, #00ff00 33%, #00ffff 50%, #0000ff 67%, #ff00ff 83%, #ff0000 100%); - background: -webkit-gradient(linear, left top, left bottom, from(#ff0000), color-stop(0.17, #ffff00), color-stop(0.33, #00ff00), color-stop(0.5, #00ffff), color-stop(0.67, #0000ff), color-stop(0.83, #ff00ff), to(#ff0000)); - background: -webkit-linear-gradient(top, #ff0000 0%, #ffff00 17%, #00ff00 33%, #00ffff 50%, #0000ff 67%, #ff00ff 83%, #ff0000 100%); - background: linear-gradient(to bottom, #ff0000 0%, #ffff00 17%, #00ff00 33%, #00ffff 50%, #0000ff 67%, #ff00ff 83%, #ff0000 100%); -} - -/* IE filters do not support multiple color stops. - Generate 6 divs, line them up, and do two color gradients for each. - Yes, really. - */ -.sp-1 { - height:17%; - filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ff0000', endColorstr='#ffff00'); -} -.sp-2 { - height:16%; - filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffff00', endColorstr='#00ff00'); -} -.sp-3 { - height:17%; - filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#00ff00', endColorstr='#00ffff'); -} -.sp-4 { - height:17%; - filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#00ffff', endColorstr='#0000ff'); -} -.sp-5 { - height:16%; - filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#0000ff', endColorstr='#ff00ff'); -} -.sp-6 { - height:17%; - filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ff00ff', endColorstr='#ff0000'); -} - -.sp-hidden { - display: none !important; -} - -/* Clearfix hack */ -.sp-cf:before, .sp-cf:after { content: ""; display: table; } -.sp-cf:after { clear: both; } -.sp-cf { *zoom: 1; } - -/* Mobile devices, make hue slider bigger so it is easier to slide */ -@media (max-device-width: 480px) { - .sp-color { right: 40%; } - .sp-hue { left: 63%; } - .sp-fill { padding-top: 60%; } -} -.sp-dragger { - border-radius: 5px; - height: 5px; - width: 5px; - border: 1px solid #fff; - background: #000; - cursor: pointer; - position:absolute; - top:0; - left: 0; -} -.sp-slider { - position: absolute; - top:0; - cursor:pointer; - height: 3px; - left: -1px; - right: -1px; - border: 1px solid #000; - background: white; - opacity: .8; -} - -/* -Theme authors: -Here are the basic themeable display options (colors, fonts, global widths). -See http://bgrins.github.io/spectrum/themes/ for instructions. -*/ - -.sp-container { - border-radius: 0; - background-color: #ECECEC; - border: solid 1px #f0c49B; - padding: 0; -} -.sp-container, .sp-container button, .sp-container input, .sp-color, .sp-hue, .sp-clear { - font: normal 12px "Lucida Grande", "Lucida Sans Unicode", "Lucida Sans", Geneva, Verdana, sans-serif; - -webkit-box-sizing: border-box; - -moz-box-sizing: border-box; - -ms-box-sizing: border-box; - box-sizing: border-box; -} -.sp-top { - margin-bottom: 3px; -} -.sp-color, .sp-hue, .sp-clear { - border: solid 1px #666; -} - -/* Input */ -.sp-input-container { - float:right; - width: 100px; - margin-bottom: 4px; -} -.sp-initial-disabled .sp-input-container { - width: 100%; -} -.sp-input { - font-size: 12px !important; - border: 1px inset; - padding: 4px 5px; - margin: 0; - width: 100%; - background:transparent; - border-radius: 3px; - color: #222; -} -.sp-input:focus { - border: 1px solid orange; -} -.sp-input.sp-validation-error { - border: 1px solid red; - background: #fdd; -} -.sp-picker-container , .sp-palette-container { - float:left; - position: relative; - padding: 10px; - padding-bottom: 300px; - margin-bottom: -290px; -} -.sp-picker-container { - width: 172px; - border-left: solid 1px #fff; -} - -/* Palettes */ -.sp-palette-container { - border-right: solid 1px #ccc; -} - -.sp-palette-only .sp-palette-container { - border: 0; -} - -.sp-palette .sp-thumb-el { - display: block; - position:relative; - float:left; - width: 24px; - height: 15px; - margin: 3px; - cursor: pointer; - border:solid 2px transparent; -} -.sp-palette .sp-thumb-el:hover, .sp-palette .sp-thumb-el.sp-thumb-active { - border-color: orange; -} -.sp-thumb-el { - position:relative; -} - -/* Initial */ -.sp-initial { - float: left; - border: solid 1px #333; -} -.sp-initial span { - width: 30px; - height: 25px; - border:none; - display:block; - float:left; - margin:0; -} - -.sp-initial .sp-clear-display { - background-position: center; -} - -/* Buttons */ -.sp-palette-button-container, -.sp-button-container { - float: right; -} - -/* Replacer (the little preview div that shows up instead of the ) */ -.sp-replacer { - margin:0; - overflow:hidden; - cursor:pointer; - padding: 4px; - display:inline-block; - *zoom: 1; - *display: inline; - border: solid 1px #91765d; - background: #eee; - color: #333; - vertical-align: middle; -} -.sp-replacer:hover, .sp-replacer.sp-active { - border-color: #F0C49B; - color: #111; -} -.sp-replacer.sp-disabled { - cursor:default; - border-color: silver; - color: silver; -} -.sp-dd { - padding: 2px 0; - height: 16px; - line-height: 16px; - float:left; - font-size:10px; -} -.sp-preview { - position:relative; - width:25px; - height: 20px; - border: solid 1px #222; - margin-right: 5px; - float:left; - z-index: 0; -} - -.sp-palette { - *width: 220px; - max-width: 220px; -} -.sp-palette .sp-thumb-el { - width:16px; - height: 16px; - margin:2px 1px; - border: solid 1px #d0d0d0; -} - -.sp-container { - padding-bottom:0; -} - - -/* Buttons: http://hellohappy.org/css3-buttons/ */ -.sp-container button { - background-color: #eeeeee; - background-image: -webkit-linear-gradient(top, #eeeeee, #cccccc); - background-image: -moz-linear-gradient(top, #eeeeee, #cccccc); - background-image: -ms-linear-gradient(top, #eeeeee, #cccccc); - background-image: -o-linear-gradient(top, #eeeeee, #cccccc); - background-image: linear-gradient(to bottom, #eeeeee, #cccccc); - border: 1px solid #ccc; - border-bottom: 1px solid #bbb; - border-radius: 3px; - color: #333; - font-size: 14px; - line-height: 1; - padding: 5px 4px; - text-align: center; - text-shadow: 0 1px 0 #eee; - vertical-align: middle; -} -.sp-container button:hover { - background-color: #dddddd; - background-image: -webkit-linear-gradient(top, #dddddd, #bbbbbb); - background-image: -moz-linear-gradient(top, #dddddd, #bbbbbb); - background-image: -ms-linear-gradient(top, #dddddd, #bbbbbb); - background-image: -o-linear-gradient(top, #dddddd, #bbbbbb); - background-image: linear-gradient(to bottom, #dddddd, #bbbbbb); - border: 1px solid #bbb; - border-bottom: 1px solid #999; - cursor: pointer; - text-shadow: 0 1px 0 #ddd; -} -.sp-container button:active { - border: 1px solid #aaa; - border-bottom: 1px solid #888; - -webkit-box-shadow: inset 0 0 5px 2px #aaaaaa, 0 1px 0 0 #eeeeee; - -moz-box-shadow: inset 0 0 5px 2px #aaaaaa, 0 1px 0 0 #eeeeee; - -ms-box-shadow: inset 0 0 5px 2px #aaaaaa, 0 1px 0 0 #eeeeee; - -o-box-shadow: inset 0 0 5px 2px #aaaaaa, 0 1px 0 0 #eeeeee; - box-shadow: inset 0 0 5px 2px #aaaaaa, 0 1px 0 0 #eeeeee; -} -.sp-cancel { - font-size: 11px; - color: #d93f3f !important; - margin:0; - padding:2px; - margin-right: 5px; - vertical-align: middle; - text-decoration:none; - -} -.sp-cancel:hover { - color: #d93f3f !important; - text-decoration: underline; -} - - -.sp-palette span:hover, .sp-palette span.sp-thumb-active { - border-color: #000; -} - -.sp-preview, .sp-alpha, .sp-thumb-el { - position:relative; - background-image: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAwAAAAMCAIAAADZF8uwAAAAGUlEQVQYV2M4gwH+YwCGIasIUwhT25BVBADtzYNYrHvv4gAAAABJRU5ErkJggg==); -} -.sp-preview-inner, .sp-alpha-inner, .sp-thumb-inner { - display:block; - position:absolute; - top:0;left:0;bottom:0;right:0; -} - -.sp-palette .sp-thumb-inner { - background-position: 50% 50%; - background-repeat: no-repeat; -} - -.sp-palette .sp-thumb-light.sp-thumb-active .sp-thumb-inner { - background-image: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABIAAAASCAYAAABWzo5XAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAIVJREFUeNpiYBhsgJFMffxAXABlN5JruT4Q3wfi/0DsT64h8UD8HmpIPCWG/KemIfOJCUB+Aoacx6EGBZyHBqI+WsDCwuQ9mhxeg2A210Ntfo8klk9sOMijaURm7yc1UP2RNCMbKE9ODK1HM6iegYLkfx8pligC9lCD7KmRof0ZhjQACDAAceovrtpVBRkAAAAASUVORK5CYII=); -} - -.sp-palette .sp-thumb-dark.sp-thumb-active .sp-thumb-inner { - background-image: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABIAAAASCAYAAABWzo5XAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAAadEVYdFNvZnR3YXJlAFBhaW50Lk5FVCB2My41LjEwMPRyoQAAAMdJREFUOE+tkgsNwzAMRMugEAahEAahEAZhEAqlEAZhEAohEAYh81X2dIm8fKpEspLGvudPOsUYpxE2BIJCroJmEW9qJ+MKaBFhEMNabSy9oIcIPwrB+afvAUFoK4H0tMaQ3XtlrggDhOVVMuT4E5MMG0FBbCEYzjYT7OxLEvIHQLY2zWwQ3D+9luyOQTfKDiFD3iUIfPk8VqrKjgAiSfGFPecrg6HN6m/iBcwiDAo7WiBeawa+Kwh7tZoSCGLMqwlSAzVDhoK+6vH4G0P5wdkAAAAASUVORK5CYII=); -} - -.sp-clear-display { - background-repeat:no-repeat; - background-position: center; - background-image: url(data:image/gif;base64,R0lGODlhFAAUAPcAAAAAAJmZmZ2dnZ6enqKioqOjo6SkpKWlpaampqenp6ioqKmpqaqqqqurq/Hx8fLy8vT09PX19ff39/j4+Pn5+fr6+vv7+wAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAACH5BAEAAP8ALAAAAAAUABQAAAihAP9FoPCvoMGDBy08+EdhQAIJCCMybCDAAYUEARBAlFiQQoMABQhKUJBxY0SPICEYHBnggEmDKAuoPMjS5cGYMxHW3IiT478JJA8M/CjTZ0GgLRekNGpwAsYABHIypcAgQMsITDtWJYBR6NSqMico9cqR6tKfY7GeBCuVwlipDNmefAtTrkSzB1RaIAoXodsABiZAEFB06gIBWC1mLVgBa0AAOw==); -} diff --git a/library/admin/ReduxCore/assets/css/vendor/spectrum/redux-spectrum.min.css b/library/admin/ReduxCore/assets/css/vendor/spectrum/redux-spectrum.min.css deleted file mode 100644 index a9fd168a..00000000 --- a/library/admin/ReduxCore/assets/css/vendor/spectrum/redux-spectrum.min.css +++ /dev/null @@ -1 +0,0 @@ -.sp-container{position:absolute;top:0;left:0;display:inline-block;*display:inline;*zoom:1;z-index:9999994;overflow:hidden}.sp-container.sp-flat{position:relative}.sp-container,.sp-container *{-webkit-box-sizing:content-box;-moz-box-sizing:content-box;box-sizing:content-box}.sp-top{position:relative;width:100%;display:inline-block}.sp-top-inner{position:absolute;top:0;left:0;bottom:0;right:0}.sp-color{position:absolute;top:0;left:0;bottom:0;right:20%}.sp-hue{position:absolute;top:0;right:0;bottom:0;left:84%;height:100%}.sp-clear-enabled .sp-hue{top:33px;height:77.5%}.sp-fill{padding-top:80%}.sp-sat,.sp-val{position:absolute;top:0;left:0;right:0;bottom:0}.sp-alpha-enabled .sp-top{margin-bottom:18px}.sp-alpha-enabled .sp-alpha{display:block}.sp-alpha-handle{position:absolute;top:-4px;bottom:-4px;width:6px;left:50%;cursor:pointer;border:1px solid black;background:white;opacity:.8}.sp-alpha{display:none;position:absolute;bottom:-14px;right:0;left:0;height:8px}.sp-alpha-inner{border:solid 1px #333}.sp-clear{display:none}.sp-clear.sp-clear-display{background-position:center}.sp-clear-enabled .sp-clear{display:block;position:absolute;top:0;right:0;bottom:0;left:84%;height:28px}.sp-container,.sp-replacer,.sp-preview,.sp-dragger,.sp-slider,.sp-alpha,.sp-clear,.sp-alpha-handle,.sp-container.sp-dragging .sp-input,.sp-container button{-webkit-user-select:none;-moz-user-select:-moz-none;-o-user-select:none;user-select:none}.sp-container.sp-input-disabled .sp-input-container{display:none}.sp-container.sp-buttons-disabled .sp-button-container{display:none}.sp-container.sp-palette-buttons-disabled .sp-palette-button-container{display:none}.sp-palette-only .sp-picker-container{display:none}.sp-palette-disabled .sp-palette-container{display:none}.sp-initial-disabled .sp-initial{display:none}.sp-sat{background-image:-webkit-gradient(linear,0 0,100% 0,from(#FFF),to(rgba(204,154,129,0)));background-image:-webkit-linear-gradient(left,#FFF,rgba(204,154,129,0));background-image:-moz-linear-gradient(left,#fff,rgba(204,154,129,0));background-image:-o-linear-gradient(left,#fff,rgba(204,154,129,0));background-image:-ms-linear-gradient(left,#fff,rgba(204,154,129,0));background-image:linear-gradient(to right,#fff,rgba(204,154,129,0));-ms-filter:"progid:DXImageTransform.Microsoft.gradient(GradientType = 1, startColorstr=#FFFFFFFF, endColorstr=#00CC9A81)";filter:progid:DXImageTransform.Microsoft.gradient(GradientType = 1,startColorstr='#FFFFFFFF',endColorstr='#00CC9A81')}.sp-val{background-image:-webkit-gradient(linear,0 100%,0 0,from(#000),to(rgba(204,154,129,0)));background-image:-webkit-linear-gradient(bottom,#000,rgba(204,154,129,0));background-image:-moz-linear-gradient(bottom,#000,rgba(204,154,129,0));background-image:-o-linear-gradient(bottom,#000,rgba(204,154,129,0));background-image:-ms-linear-gradient(bottom,#000,rgba(204,154,129,0));background-image:linear-gradient(to top,#000,rgba(204,154,129,0));-ms-filter:"progid:DXImageTransform.Microsoft.gradient(startColorstr=#00CC9A81, endColorstr=#FF000000)";filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#00CC9A81',endColorstr='#FF000000')}.sp-hue{background:-moz-linear-gradient(top,#f00 0,#ff0 17%,#0f0 33%,#0ff 50%,#00f 67%,#f0f 83%,#f00 100%);background:-ms-linear-gradient(top,#f00 0,#ff0 17%,#0f0 33%,#0ff 50%,#00f 67%,#f0f 83%,#f00 100%);background:-o-linear-gradient(top,#f00 0,#ff0 17%,#0f0 33%,#0ff 50%,#00f 67%,#f0f 83%,#f00 100%);background:-webkit-gradient(linear,left top,left bottom,from(#f00),color-stop(0.17,#ff0),color-stop(0.33,#0f0),color-stop(0.5,#0ff),color-stop(0.67,#00f),color-stop(0.83,#f0f),to(#f00));background:-webkit-linear-gradient(top,#f00 0,#ff0 17%,#0f0 33%,#0ff 50%,#00f 67%,#f0f 83%,#f00 100%);background:linear-gradient(to bottom,#f00 0,#ff0 17%,#0f0 33%,#0ff 50%,#00f 67%,#f0f 83%,#f00 100%)}.sp-1{height:17%;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#ff0000',endColorstr='#ffff00')}.sp-2{height:16%;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffff00',endColorstr='#00ff00')}.sp-3{height:17%;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#00ff00',endColorstr='#00ffff')}.sp-4{height:17%;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#00ffff',endColorstr='#0000ff')}.sp-5{height:16%;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#0000ff',endColorstr='#ff00ff')}.sp-6{height:17%;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#ff00ff',endColorstr='#ff0000')}.sp-hidden{display:none!important}.sp-cf:before,.sp-cf:after{content:"";display:table}.sp-cf:after{clear:both}.sp-cf{*zoom:1}@media(max-device-width:480px){.sp-color{right:40%}.sp-hue{left:63%}.sp-fill{padding-top:60%}}.sp-dragger{border-radius:5px;height:5px;width:5px;border:1px solid #fff;background:#000;cursor:pointer;position:absolute;top:0;left:0}.sp-slider{position:absolute;top:0;cursor:pointer;height:3px;left:-1px;right:-1px;border:1px solid #000;background:white;opacity:.8}.sp-container{border-radius:0;background-color:#ececec;border:solid 1px #f0c49b;padding:0}.sp-container,.sp-container button,.sp-container input,.sp-color,.sp-hue,.sp-clear{font:normal 12px "Lucida Grande","Lucida Sans Unicode","Lucida Sans",Geneva,Verdana,sans-serif;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;-ms-box-sizing:border-box;box-sizing:border-box}.sp-top{margin-bottom:3px}.sp-color,.sp-hue,.sp-clear{border:solid 1px #666}.sp-input-container{float:right;width:100px;margin-bottom:4px}.sp-initial-disabled .sp-input-container{width:100%}.sp-input{font-size:12px!important;border:1px inset;padding:4px 5px;margin:0;width:100%;background:transparent;border-radius:3px;color:#222}.sp-input:focus{border:1px solid orange}.sp-input.sp-validation-error{border:1px solid red;background:#fdd}.sp-picker-container,.sp-palette-container{float:left;position:relative;padding:10px;padding-bottom:300px;margin-bottom:-290px}.sp-picker-container{width:172px;border-left:solid 1px #fff}.sp-palette-container{border-right:solid 1px #ccc}.sp-palette-only .sp-palette-container{border:0}.sp-palette .sp-thumb-el{display:block;position:relative;float:left;width:24px;height:15px;margin:3px;cursor:pointer;border:solid 2px transparent}.sp-palette .sp-thumb-el:hover,.sp-palette .sp-thumb-el.sp-thumb-active{border-color:orange}.sp-thumb-el{position:relative}.sp-initial{float:left;border:solid 1px #333}.sp-initial span{width:30px;height:25px;border:0;display:block;float:left;margin:0}.sp-initial .sp-clear-display{background-position:center}.sp-palette-button-container,.sp-button-container{float:right}.sp-replacer{margin:0;overflow:hidden;cursor:pointer;padding:4px;display:inline-block;*zoom:1;*display:inline;border:solid 1px #91765d;background:#eee;color:#333;vertical-align:middle}.sp-replacer:hover,.sp-replacer.sp-active{border-color:#f0c49b;color:#111}.sp-replacer.sp-disabled{cursor:default;border-color:silver;color:silver}.sp-dd{padding:2px 0;height:16px;line-height:16px;float:left;font-size:10px}.sp-preview{position:relative;width:25px;height:20px;border:solid 1px #222;margin-right:5px;float:left;z-index:0}.sp-palette{*width:220px;max-width:220px}.sp-palette .sp-thumb-el{width:16px;height:16px;margin:2px 1px;border:solid 1px #d0d0d0}.sp-container{padding-bottom:0}.sp-container button{background-color:#eee;background-image:-webkit-linear-gradient(top,#eee,#ccc);background-image:-moz-linear-gradient(top,#eee,#ccc);background-image:-ms-linear-gradient(top,#eee,#ccc);background-image:-o-linear-gradient(top,#eee,#ccc);background-image:linear-gradient(to bottom,#eee,#ccc);border:1px solid #ccc;border-bottom:1px solid #bbb;border-radius:3px;color:#333;font-size:14px;line-height:1;padding:5px 4px;text-align:center;text-shadow:0 1px 0 #eee;vertical-align:middle}.sp-container button:hover{background-color:#ddd;background-image:-webkit-linear-gradient(top,#ddd,#bbb);background-image:-moz-linear-gradient(top,#ddd,#bbb);background-image:-ms-linear-gradient(top,#ddd,#bbb);background-image:-o-linear-gradient(top,#ddd,#bbb);background-image:linear-gradient(to bottom,#ddd,#bbb);border:1px solid #bbb;border-bottom:1px solid #999;cursor:pointer;text-shadow:0 1px 0 #ddd}.sp-container button:active{border:1px solid #aaa;border-bottom:1px solid #888;-webkit-box-shadow:inset 0 0 5px 2px #aaa,0 1px 0 0 #eee;-moz-box-shadow:inset 0 0 5px 2px #aaa,0 1px 0 0 #eee;-ms-box-shadow:inset 0 0 5px 2px #aaa,0 1px 0 0 #eee;-o-box-shadow:inset 0 0 5px 2px #aaa,0 1px 0 0 #eee;box-shadow:inset 0 0 5px 2px #aaa,0 1px 0 0 #eee}.sp-cancel{font-size:11px;color:#d93f3f!important;margin:0;padding:2px;margin-right:5px;vertical-align:middle;text-decoration:none}.sp-cancel:hover{color:#d93f3f!important;text-decoration:underline}.sp-palette span:hover,.sp-palette span.sp-thumb-active{border-color:#000}.sp-preview,.sp-alpha,.sp-thumb-el{position:relative;background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAwAAAAMCAIAAADZF8uwAAAAGUlEQVQYV2M4gwH+YwCGIasIUwhT25BVBADtzYNYrHvv4gAAAABJRU5ErkJggg==)}.sp-preview-inner,.sp-alpha-inner,.sp-thumb-inner{display:block;position:absolute;top:0;left:0;bottom:0;right:0}.sp-palette .sp-thumb-inner{background-position:50% 50%;background-repeat:no-repeat}.sp-palette .sp-thumb-light.sp-thumb-active .sp-thumb-inner{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABIAAAASCAYAAABWzo5XAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAIVJREFUeNpiYBhsgJFMffxAXABlN5JruT4Q3wfi/0DsT64h8UD8HmpIPCWG/KemIfOJCUB+Aoacx6EGBZyHBqI+WsDCwuQ9mhxeg2A210Ntfo8klk9sOMijaURm7yc1UP2RNCMbKE9ODK1HM6iegYLkfx8pligC9lCD7KmRof0ZhjQACDAAceovrtpVBRkAAAAASUVORK5CYII=)}.sp-palette .sp-thumb-dark.sp-thumb-active .sp-thumb-inner{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABIAAAASCAYAAABWzo5XAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAAadEVYdFNvZnR3YXJlAFBhaW50Lk5FVCB2My41LjEwMPRyoQAAAMdJREFUOE+tkgsNwzAMRMugEAahEAahEAZhEAqlEAZhEAohEAYh81X2dIm8fKpEspLGvudPOsUYpxE2BIJCroJmEW9qJ+MKaBFhEMNabSy9oIcIPwrB+afvAUFoK4H0tMaQ3XtlrggDhOVVMuT4E5MMG0FBbCEYzjYT7OxLEvIHQLY2zWwQ3D+9luyOQTfKDiFD3iUIfPk8VqrKjgAiSfGFPecrg6HN6m/iBcwiDAo7WiBeawa+Kwh7tZoSCGLMqwlSAzVDhoK+6vH4G0P5wdkAAAAASUVORK5CYII=)}.sp-clear-display{background-repeat:no-repeat;background-position:center;background-image:url(data:image/gif;base64,R0lGODlhFAAUAPcAAAAAAJmZmZ2dnZ6enqKioqOjo6SkpKWlpaampqenp6ioqKmpqaqqqqurq/Hx8fLy8vT09PX19ff39/j4+Pn5+fr6+vv7+wAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAACH5BAEAAP8ALAAAAAAUABQAAAihAP9FoPCvoMGDBy08+EdhQAIJCCMybCDAAYUEARBAlFiQQoMABQhKUJBxY0SPICEYHBnggEmDKAuoPMjS5cGYMxHW3IiT478JJA8M/CjTZ0GgLRekNGpwAsYABHIypcAgQMsITDtWJYBR6NSqMico9cqR6tKfY7GeBCuVwlipDNmefAtTrkSzB1RaIAoXodsABiZAEFB06gIBWC1mLVgBa0AAOw==)} \ No newline at end of file diff --git a/library/admin/ReduxCore/assets/img/1c.png b/library/admin/ReduxCore/assets/img/1c.png deleted file mode 100644 index 6bbb1c31..00000000 Binary files a/library/admin/ReduxCore/assets/img/1c.png and /dev/null differ diff --git a/library/admin/ReduxCore/assets/img/1col.png b/library/admin/ReduxCore/assets/img/1col.png deleted file mode 100644 index 1664aa73..00000000 Binary files a/library/admin/ReduxCore/assets/img/1col.png and /dev/null differ diff --git a/library/admin/ReduxCore/assets/img/2-col-portfolio.png b/library/admin/ReduxCore/assets/img/2-col-portfolio.png deleted file mode 100644 index be72cb13..00000000 Binary files a/library/admin/ReduxCore/assets/img/2-col-portfolio.png and /dev/null differ diff --git a/library/admin/ReduxCore/assets/img/2cl.png b/library/admin/ReduxCore/assets/img/2cl.png deleted file mode 100644 index 5a9baf7e..00000000 Binary files a/library/admin/ReduxCore/assets/img/2cl.png and /dev/null differ diff --git a/library/admin/ReduxCore/assets/img/2cr.png b/library/admin/ReduxCore/assets/img/2cr.png deleted file mode 100644 index 0624bfc7..00000000 Binary files a/library/admin/ReduxCore/assets/img/2cr.png and /dev/null differ diff --git a/library/admin/ReduxCore/assets/img/3-col-portfolio.png b/library/admin/ReduxCore/assets/img/3-col-portfolio.png deleted file mode 100644 index aa7d45ac..00000000 Binary files a/library/admin/ReduxCore/assets/img/3-col-portfolio.png and /dev/null differ diff --git a/library/admin/ReduxCore/assets/img/3cl.png b/library/admin/ReduxCore/assets/img/3cl.png deleted file mode 100644 index 865634cf..00000000 Binary files a/library/admin/ReduxCore/assets/img/3cl.png and /dev/null differ diff --git a/library/admin/ReduxCore/assets/img/3cm.png b/library/admin/ReduxCore/assets/img/3cm.png deleted file mode 100644 index bb8c4fe0..00000000 Binary files a/library/admin/ReduxCore/assets/img/3cm.png and /dev/null differ diff --git a/library/admin/ReduxCore/assets/img/3cr.png b/library/admin/ReduxCore/assets/img/3cr.png deleted file mode 100644 index 61773a55..00000000 Binary files a/library/admin/ReduxCore/assets/img/3cr.png and /dev/null differ diff --git a/library/admin/ReduxCore/assets/img/4-col-portfolio.png b/library/admin/ReduxCore/assets/img/4-col-portfolio.png deleted file mode 100644 index 907eba23..00000000 Binary files a/library/admin/ReduxCore/assets/img/4-col-portfolio.png and /dev/null differ diff --git a/library/admin/ReduxCore/assets/img/ajax.gif b/library/admin/ReduxCore/assets/img/ajax.gif deleted file mode 100644 index e1469616..00000000 Binary files a/library/admin/ReduxCore/assets/img/ajax.gif and /dev/null differ diff --git a/library/admin/ReduxCore/assets/img/menu_icon.png b/library/admin/ReduxCore/assets/img/menu_icon.png deleted file mode 100644 index da87bf70..00000000 Binary files a/library/admin/ReduxCore/assets/img/menu_icon.png and /dev/null differ diff --git a/library/admin/ReduxCore/assets/img/toggle_tabs.png b/library/admin/ReduxCore/assets/img/toggle_tabs.png deleted file mode 100644 index ff435fb3..00000000 Binary files a/library/admin/ReduxCore/assets/img/toggle_tabs.png and /dev/null differ diff --git a/library/admin/ReduxCore/assets/js/media/media.js b/library/admin/ReduxCore/assets/js/media/media.js deleted file mode 100644 index 0c0f3491..00000000 --- a/library/admin/ReduxCore/assets/js/media/media.js +++ /dev/null @@ -1,220 +0,0 @@ -/*global redux_change, wp, redux, libFilter */ - -/** - * Media Uploader - * Dependencies : jquery, wp media uploader - * Feature added by : Smartik - http://smartik.ws/ - * Date : 05.28.2013 - */ - -(function($){ - "use strict"; - - redux.field_objects = redux.field_objects || {}; - redux.field_objects.media = redux.field_objects.media || {}; - - var isFiltered; - - $( document ).ready( - function() { - - } - ); - - redux.field_objects.media.init = function( selector ) { - if ( !selector ) { - selector = $( document ).find( ".redux-group-tab:visible" ).find( '.redux-container-media:visible' ); - } - $( selector ).each( - function() { - var el = $( this ); - var parent = el; - - if ( !el.hasClass( 'redux-field-container' ) ) { - parent = el.parents( '.redux-field-container:first' ); - } - if ( parent.is( ":hidden" ) ) { // Skip hidden fields - return; - } - if ( parent.hasClass( 'redux-field-init' ) ) { - parent.removeClass( 'redux-field-init' ); - } else { - return; - } - - isFiltered = false; - - // Remove the image button - el.find( '.remove-image, .remove-file' ).unbind( 'click' ).on( - 'click', function() { - redux.field_objects.media.removeFile( $( this ).parents( 'fieldset.redux-field:first' ) ); - } - ); - // Upload media button - el.find( '.media_upload_button' ).unbind().on( - 'click', function( event ) { - redux.field_objects.media.addFile( event, $( this ).parents( 'fieldset.redux-field:first' ) ); - } - ); - } - ); - }; - - // Add a file via the wp.media function - redux.field_objects.media.addFile = function( event, selector ) { - event.preventDefault(); - - var frame; - var jQueryel = $( this ); - var libFilter; - - // If the media frame already exists, reopen it. - if ( frame ) { - frame.open(); - return; - } - - // Get library filter data - var filter = $( selector ).find('.library-filter').data('lib-filter'); - - // Must exist to do decoding - if (filter !== undefined) { - if (filter !== ''){ - libFilter = []; - isFiltered = true; - filter = decodeURIComponent(filter); - filter = JSON.parse(filter); - - $.each(filter, function(index, value) { - libFilter.push(value); - }); - } - } - - // Create the media frame. - frame = wp.media( - { - multiple: false, - library: { - type: libFilter //Only allow images - }, - - // Set the title of the modal. - title: jQueryel.data( 'choose' ), - - // Customize the submit button. - button: { - // Set the text of the button. - text: jQueryel.data( 'update' ) - // Tell the button not to close the modal, since we're - // going to refresh the page when the image is selected. - } - } - ); - - // When an image is selected, run a callback. - frame.on( - 'select', function() { - - // Grab the selected attachment. - var attachment = frame.state().get( 'selection' ).first(); - frame.close(); - - var data = $( selector ).find('.data').data(); - - if ( typeof redux.field_objects.media === 'undefined' || typeof redux.field_objects.media === undefined ) { - redux.field_objects.media = {}; - } - - if ( data === undefined || data.mode === 'undefined' ) { - data = {}; - data.mode = "image"; - } - - if (isFiltered === true) { - data.mode = 0; - } - - if (data.mode === 0) { - - } else { - if ( data.mode !== false) { - if (attachment.attributes.type !== data.mode) { - if (attachment.attributes.subtype !== data.mode ) { - return; - } - } - } - } - - selector.find( '.upload' ).val( attachment.attributes.url ); - selector.find( '.upload-id' ).val( attachment.attributes.id ); - selector.find( '.upload-height' ).val( attachment.attributes.height ); - selector.find( '.upload-width' ).val( attachment.attributes.width ); - - redux_change( $( selector ).find( '.upload-id' ) ); - - var thumbSrc = attachment.attributes.url; - if ( typeof attachment.attributes.sizes !== 'undefined' && typeof attachment.attributes.sizes.thumbnail !== 'undefined' ) { - thumbSrc = attachment.attributes.sizes.thumbnail.url; - } else if ( typeof attachment.attributes.sizes !== 'undefined' ) { - var height = attachment.attributes.height; - - for ( var key in attachment.attributes.sizes ) { - var object = attachment.attributes.sizes[key]; - - if ( object.height < height ) { - height = object.height; - thumbSrc = object.url; - } - } - } else { - thumbSrc = attachment.attributes.icon; - } - - selector.find( '.upload-thumbnail' ).val( thumbSrc ); - if ( !selector.find( '.upload' ).hasClass( 'noPreview' ) ) { - selector.find( '.screenshot' ).empty().hide().append( '' ).slideDown( 'fast' ); - } - - //selector.find('.media_upload_button').unbind(); - selector.find( '.remove-image' ).removeClass( 'hide' );//show "Remove" button - selector.find( '.redux-background-properties' ).slideDown(); - } - ); - - // Finally, open the modal. - frame.open(); - }; - - // Function to remove the image on click. Still requires a save - redux.field_objects.media.removeFile = function( selector ) { - - // This shouldn't have been run... - if ( !selector.find( '.remove-image' ).addClass( 'hide' ) ) { - return; - } - - selector.find( '.remove-image' ).addClass( 'hide' );//hide "Remove" button - selector.find( '.upload' ).val( '' ); - selector.find( '.upload-id' ).val( '' ); - selector.find( '.upload-height' ).val( '' ); - selector.find( '.upload-width' ).val( '' ); - selector.find( '.upload-thumbnail' ).val( '' ); - redux_change( $( selector ).find( '.upload-id' ) ); - selector.find( '.redux-background-properties' ).hide(); - - var screenshot = selector.find( '.screenshot' ); - - // Hide the screenshot - screenshot.slideUp(); - - selector.find( '.remove-file' ).unbind(); - - // We don't display the upload button if .upload-notice is present - // This means the user doesn't have the WordPress 3.5 Media Library Support - if ( selector.find( '.section-upload .upload-notice' ).length > 0 ) { - selector.find( '.media_upload_button' ).remove(); - } - }; -})( jQuery ); \ No newline at end of file diff --git a/library/admin/ReduxCore/assets/js/media/media.min.js b/library/admin/ReduxCore/assets/js/media/media.min.js deleted file mode 100644 index 8c7bb839..00000000 --- a/library/admin/ReduxCore/assets/js/media/media.min.js +++ /dev/null @@ -1 +0,0 @@ -!function(a){"use strict";redux.field_objects=redux.field_objects||{},redux.field_objects.media=redux.field_objects.media||{};var b;a(document).ready(function(){}),redux.field_objects.media.init=function(c){c||(c=a(document).find(".redux-group-tab:visible").find(".redux-container-media:visible")),a(c).each(function(){var c=a(this),d=c;c.hasClass("redux-field-container")||(d=c.parents(".redux-field-container:first")),d.is(":hidden")||d.hasClass("redux-field-init")&&(d.removeClass("redux-field-init"),b=!1,c.find(".remove-image, .remove-file").unbind("click").on("click",function(){redux.field_objects.media.removeFile(a(this).parents("fieldset.redux-field:first"))}),c.find(".media_upload_button").unbind().on("click",function(b){redux.field_objects.media.addFile(b,a(this).parents("fieldset.redux-field:first"))}))})},redux.field_objects.media.addFile=function(c,d){c.preventDefault();var e,f,g=a(this);if(e)return void e.open();var h=a(d).find(".library-filter").data("lib-filter");void 0!==h&&""!==h&&(f=[],b=!0,h=decodeURIComponent(h),h=JSON.parse(h),a.each(h,function(a,b){f.push(b)})),e=wp.media({multiple:!1,library:{type:f},title:g.data("choose"),button:{text:g.data("update")}}),e.on("select",function(){var c=e.state().get("selection").first();e.close();var f=a(d).find(".data").data();if(("undefined"==typeof redux.field_objects.media||void 0===typeof redux.field_objects.media)&&(redux.field_objects.media={}),(void 0===f||"undefined"===f.mode)&&(f={},f.mode="image"),b===!0&&(f.mode=0),0===f.mode);else if(f.mode!==!1&&c.attributes.type!==f.mode&&c.attributes.subtype!==f.mode)return;d.find(".upload").val(c.attributes.url),d.find(".upload-id").val(c.attributes.id),d.find(".upload-height").val(c.attributes.height),d.find(".upload-width").val(c.attributes.width),redux_change(a(d).find(".upload-id"));var g=c.attributes.url;if("undefined"!=typeof c.attributes.sizes&&"undefined"!=typeof c.attributes.sizes.thumbnail)g=c.attributes.sizes.thumbnail.url;else if("undefined"!=typeof c.attributes.sizes){var h=c.attributes.height;for(var i in c.attributes.sizes){var j=c.attributes.sizes[i];j.height').slideDown("fast"),d.find(".remove-image").removeClass("hide"),d.find(".redux-background-properties").slideDown()}),e.open()},redux.field_objects.media.removeFile=function(b){if(b.find(".remove-image").addClass("hide")){b.find(".remove-image").addClass("hide"),b.find(".upload").val(""),b.find(".upload-id").val(""),b.find(".upload-height").val(""),b.find(".upload-width").val(""),b.find(".upload-thumbnail").val(""),redux_change(a(b).find(".upload-id")),b.find(".redux-background-properties").hide();var c=b.find(".screenshot");c.slideUp(),b.find(".remove-file").unbind(),b.find(".section-upload .upload-notice").length>0&&b.find(".media_upload_button").remove()}}}(jQuery); \ No newline at end of file diff --git a/library/admin/ReduxCore/assets/js/redux.js b/library/admin/ReduxCore/assets/js/redux.js deleted file mode 100644 index cd01a02b..00000000 --- a/library/admin/ReduxCore/assets/js/redux.js +++ /dev/null @@ -1,1772 +0,0 @@ -/* global redux, confirm, relid:true, jsonView */ - -(function( $ ) { - 'use strict'; - - $.redux = $.redux || {}; - - $( document ).ready( - function() { - $.fn.isOnScreen = function() { - if ( !window ) { - return; - } - - var win = $( window ); - var viewport = { - top: win.scrollTop(), - }; - - viewport.right = viewport.left + win.width(); - viewport.bottom = viewport.top + win.height(); - - var bounds = this.offset(); - - bounds.right = bounds.left + this.outerWidth(); - bounds.bottom = bounds.top + this.outerHeight(); - - return (!(viewport.right < bounds.left || viewport.left > bounds.right || viewport.bottom < bounds.top || viewport.top > bounds.bottom)); - }; - - $.redux.hideFields(); - $.redux.checkRequired(); - $.redux.initEvents(); - $.redux.initQtip(); - $.redux.tabCheck(); - $.redux.notices(); - $.redux.tabControl(); - } - ); - - $.redux.ajax_save = function( button ) { - - var overlay = $( document.getElementById( 'redux_ajax_overlay' ) ); - overlay.fadeIn(); - - // Add the loading mechanism - jQuery( '.redux-action_bar .spinner' ).addClass( 'is-active' ); - - jQuery( '.redux-action_bar input' ).attr( 'disabled', 'disabled' ); - var $notification_bar = jQuery( document.getElementById( 'redux_notification_bar' ) ); - $notification_bar.slideUp(); - jQuery( '.redux-save-warn' ).slideUp(); - jQuery( '.redux_ajax_save_error' ).slideUp( - 'medium', function() { - jQuery( this ).remove(); - } - ); - - var $parent = jQuery( document.getElementById( "redux-form-wrapper" ) ); - - // Editor field doesn't auto save. Have to call it. Boo. - if ( redux.fields.hasOwnProperty( "editor" ) ) { - $.each( - redux.fields.editor, function( $key, $index ) { - var editor = tinyMCE.get( $key ); - if ( editor ) { - editor.save(); - } - } - ); - } - - var $data = $parent.serialize(); - // add values for checked and unchecked checkboxes fields - $parent.find( 'input[type=checkbox]' ).each( - function() { - if ( typeof $( this ).attr( 'name' ) !== "undefined" ) { - var chkVal = $( this ).is( ':checked' ) ? $( this ).val() : "0"; - $data += "&" + $( this ).attr( 'name' ) + "=" + chkVal; - } - } - ); - - - if ( button.attr( 'name' ) != "redux_save" ) { - $data += "&" + button.attr( 'name' ) + "=" + button.val(); - } - - var $nonce = $parent.attr( "data-nonce" ); - - jQuery.ajax( - { - type: "post", - dataType: "json", - url: ajaxurl, - data: { - action: redux.args.opt_name + "_ajax_save", - nonce: $nonce, - 'opt_name': redux.args.opt_name, - data: $data - }, - error: function( response ) { - if ( !window.console ) console = {}; - console.log = console.log || function( name, data ) { - }; - console.log( redux.ajax.console ); - console.log( response.responseText ); - jQuery( '.redux-action_bar input' ).removeAttr( 'disabled' ); - overlay.fadeOut( 'fast' ); - jQuery( '.redux-action_bar .spinner' ).removeClass( 'is-active' ); - alert( redux.ajax.alert ); - }, - success: function( response ) { - if ( response.action && response.action == "reload" ) { - location.reload( true ); - } else if ( response.status == "success" ) { - jQuery( '.redux-action_bar input' ).removeAttr( 'disabled' ); - overlay.fadeOut( 'fast' ); - jQuery( '.redux-action_bar .spinner' ).removeClass( 'is-active' ); - redux.options = response.options; - //redux.defaults = response.defaults; - redux.errors = response.errors; - redux.warnings = response.warnings; - - $notification_bar.html( response.notification_bar ).slideDown( 'fast' ); - if ( response.errors !== null || response.warnings !== null ) { - $.redux.notices(); - } - var $save_notice = $( document.getElementById( 'redux_notification_bar' ) ).find( '.saved_notice' ); - $save_notice.slideDown(); - $save_notice.delay( 4000 ).slideUp(); - } else { - jQuery( '.redux-action_bar input' ).removeAttr( 'disabled' ); - jQuery( '.redux-action_bar .spinner' ).removeClass( 'is-active' ); - overlay.fadeOut( 'fast' ); - jQuery( '.wrap h2:first' ).parent().append( '' ); - jQuery( '.redux_ajax_save_error' ).slideDown(); - jQuery( "html, body" ).animate( {scrollTop: 0}, "slow" ); - } - } - } - ); - return false; - }; - - $.redux.initEvents = function() { - $( '.redux-presets-bar' ).on( - 'click', function() { - window.onbeforeunload = null; - } - ); - - - $( '#toplevel_page_' + redux.args.slug + ' .wp-submenu a, #wp-admin-bar-' + redux.args.slug + ' a.ab-item' ).click( - function( e ) { - - if ( ( $( '#toplevel_page_' + redux.args.slug ).hasClass( 'wp-menu-open' ) || $( this ).hasClass( 'ab-item' ) ) && !$( this ).parents( 'ul.ab-submenu:first' ).hasClass( 'ab-sub-secondary' ) && $( this ).attr( 'href' ).toLowerCase().indexOf( redux.args.slug + "&tab=" ) >= 0 ) { - e.preventDefault(); - var url = $( this ).attr( 'href' ).split( '&tab=' ); - $( '#' + url[1] + '_section_group_li_a' ).click(); - $( this ).parents( 'ul:first' ).find( '.current' ).removeClass( 'current' ); - $( this ).addClass( 'current' ); - $( this ).parent().addClass( 'current' ); - return false; - } - } - ); - - // Save button clicked - $( '.redux-action_bar input' ).on( - 'click', function( e ) { - if ( $( this ).attr( 'name' ) == redux.args.opt_name + '[defaults]' ) { - // Defaults button clicked - if ( !confirm( redux.args.reset_confirm ) ) { - return false; - } - } else if ( $( this ).attr( 'name' ) == redux.args.opt_name + '[defaults-section]' ) { - // Default section clicked - if ( !confirm( redux.args.reset_section_confirm ) ) { - return false; - } - } - - window.onbeforeunload = null; - - if ( redux.args.ajax_save === true ) { - $.redux.ajax_save( $( this ) ); - e.preventDefault(); - } - } - ); - // - //// Default button clicked - //$( 'input[name="' + redux.args.opt_name + '[defaults]"]' ).click( - // function() { - // if ( !confirm( redux.args.reset_confirm ) ) { - // return false; - // } - // window.onbeforeunload = null; - // } - //); - - - //$( 'input[name="' + redux.args.opt_name + '[defaults-section]"]' ).click( - // function() { - // if ( !confirm( redux.args.reset_section_confirm ) ) { - // return false; - // } - // - // window.onbeforeunload = null; - // } - //); - //$( '.redux-save' ).click( - // function() { - // window.onbeforeunload = null; - // } - //); - - $( '.expand_options' ).click( - function( e ) { - - e.preventDefault(); - - var container = $( '.redux-container' ); - if ( $( container ).hasClass( 'fully-expanded' ) ) { - $( container ).removeClass( 'fully-expanded' ); - - var tab = $.cookie( "redux_current_tab" ); - - $( '.redux-container:first' ).find( '#' + tab + '_section_group' ).fadeIn( - 200, function() { - if ( $( '.redux-container:first' ).find( '#redux-footer' ).length !== 0 ) { - $.redux.stickyInfo(); // race condition fix - } - $.redux.initFields(); - } - ); - } - - $.redux.expandOptions( $( this ).parents( '.redux-container:first' ) ); - - return false; - } - ); - - if ( $( '.saved_notice' ).is( ':visible' ) ) { - $( '.saved_notice' ).slideDown(); - } - - $( document.body ).on( - 'change', '.redux-field input, .redux-field textarea, .redux-field select', function() { - if ( !$( this ).hasClass( 'noUpdate' ) ) { - redux_change( $( this ) ); - } - } - ); - - var stickyHeight = $( '#redux-footer' ).height(); - - $( '#redux-sticky-padder' ).css( - { - height: stickyHeight - } - ); - $( '#redux-footer-sticky' ).removeClass( 'hide' ); - - if ( $( '#redux-footer' ).length !== 0 ) { - $( window ).scroll( - function() { - $.redux.stickyInfo(); - } - ); - - $( window ).resize( - function() { - $.redux.stickyInfo(); - } - ); - } - - $( '.saved_notice' ).delay( 4000 ).slideUp(); - - - }; - - $.redux.hideFields = function() { - $( "label[for='redux_hide_field']" ).each( - function( idx, val ) { - var tr = $( this ).parent().parent(); - $( tr ).addClass( 'hidden' ); - } - ); - }; - - $.redux.checkRequired = function() { - $.redux.required(); - - $( "body" ).on( - 'change', - '.redux-main select, .redux-main radio, .redux-main input[type=checkbox], .redux-main input[type=hidden]', - function( e ) { - $.redux.check_dependencies( this ); - } - ); - - $( "body" ).on( - 'check_dependencies', function( e, variable ) { - $.redux.check_dependencies( variable ); - } - ); - - $( 'td > fieldset:empty,td > div:empty' ).parent().parent().hide(); - }; - - $.redux.initQtip = function() { - if ( $().qtip ) { - // Shadow - var shadow = ''; - var tip_shadow = redux.args.hints.tip_style.shadow; - - if ( tip_shadow === true ) { - shadow = 'qtip-shadow'; - } - - // Color - var color = ''; - var tip_color = redux.args.hints.tip_style.color; - - if ( tip_color !== '' ) { - color = 'qtip-' + tip_color; - } - - // Rounded - var rounded = ''; - var tip_rounded = redux.args.hints.tip_style.rounded; - - if ( tip_rounded === true ) { - rounded = 'qtip-rounded'; - } - - // Tip style - var style = ''; - var tip_style = redux.args.hints.tip_style.style; - - if ( tip_style !== '' ) { - style = 'qtip-' + tip_style; - } - - var classes = shadow + ',' + color + ',' + rounded + ',' + style + ',redux-qtip'; - classes = classes.replace( /,/g, ' ' ); - - // Get position data - var myPos = redux.args.hints.tip_position.my; - var atPos = redux.args.hints.tip_position.at; - - // Gotta be lowercase, and in proper format - myPos = $.redux.verifyPos( myPos.toLowerCase(), true ); - atPos = $.redux.verifyPos( atPos.toLowerCase(), false ); - - // Tooltip trigger action - var showEvent = redux.args.hints.tip_effect.show.event; - var hideEvent = redux.args.hints.tip_effect.hide.event; - - // Tip show effect - var tipShowEffect = redux.args.hints.tip_effect.show.effect; - var tipShowDuration = redux.args.hints.tip_effect.show.duration; - - // Tip hide effect - var tipHideEffect = redux.args.hints.tip_effect.hide.effect; - var tipHideDuration = redux.args.hints.tip_effect.hide.duration; - - $( 'div.redux-dev-qtip' ).each( - function() { - $( this ).qtip( - { - content: { - text: $( this ).attr( 'qtip-content' ), - title: $( this ).attr( 'qtip-title' ) - }, - show: { - effect: function() { - $( this ).slideDown( 500 ); - }, - event: 'mouseover', - }, - hide: { - effect: function() { - $( this ).slideUp( 500 ); - }, - event: 'mouseleave', - }, - style: { - classes: 'qtip-shadow qtip-light', - }, - position: { - my: 'top center', - at: 'bottom center', - }, - } - ); - } - ); - - $( 'div.redux-hint-qtip' ).each( - function() { - $( this ).qtip( - { - content: { - text: $( this ).attr( 'qtip-content' ), - title: $( this ).attr( 'qtip-title' ) - }, - show: { - effect: function() { - switch ( tipShowEffect ) { - case 'slide': - $( this ).slideDown( tipShowDuration ); - break; - case 'fade': - $( this ).fadeIn( tipShowDuration ); - break; - default: - $( this ).show(); - break; - } - }, - event: showEvent, - }, - hide: { - effect: function() { - switch ( tipHideEffect ) { - case 'slide': - $( this ).slideUp( tipHideDuration ); - break; - case 'fade': - $( this ).fadeOut( tipHideDuration ); - break; - default: - $( this ).hide( tipHideDuration ); - break; - } - }, - event: hideEvent, - }, - style: { - classes: classes, - }, - position: { - my: myPos, - at: atPos, - }, - } - ); - } - ); - // }); - - $( 'input[qtip-content]' ).each( - function() { - $( this ).qtip( - { - content: { - text: $( this ).attr( 'qtip-content' ), - title: $( this ).attr( 'qtip-title' ) - }, - show: 'focus', - hide: 'blur', - style: classes, - position: { - my: myPos, - at: atPos, - }, - } - ); - } - ); - } - }; - - $.redux.tabCheck = function() { - $( '.redux-group-tab-link-a' ).click( - function() { - var link = $( this ); - if ( link.parent().hasClass( 'empty_section' ) && link.parent().hasClass( 'hasSubSections' ) ) { - var elements = $( this ).closest( 'ul' ).find( '.redux-group-tab-link-a' ); - var index = elements.index( this ); - link = elements.slice( index + 1, index + 2 ); - } - var el = link.parents( '.redux-container:first' ); - var relid = link.data( 'rel' ); // The group ID of interest - var oldid = el.find( '.redux-group-tab-link-li.active:first .redux-group-tab-link-a' ).data( 'rel' ); - - //console.log('id: '+relid+' oldid: '+oldid); - - if ( oldid === relid ) { - return; - } - - $( '#currentSection' ).val( relid ); - if ( !link.parents( '.postbox-container:first' ).length ) { - // Set the proper page cookie - $.cookie( - 'redux_current_tab', relid, { - expires: 7, - path: '/' - } - ); - } - - if ( el.find( '#' + relid + '_section_group_li' ).parents( '.redux-group-tab-link-li' ).length ) { - var parentID = el.find( '#' + relid + '_section_group_li' ).parents( '.redux-group-tab-link-li' ).attr( 'id' ).split( '_' ); - parentID = parentID[0]; - } - - el.find( '#toplevel_page_' + redux.args.slug + ' .wp-submenu a.current' ).removeClass( 'current' ); - el.find( '#toplevel_page_' + redux.args.slug + ' .wp-submenu li.current' ).removeClass( 'current' ); - - el.find( '#toplevel_page_' + redux.args.slug + ' .wp-submenu a' ).each( - function() { - var url = $( this ).attr( 'href' ).split( '&tab=' ); - if ( url[1] == relid || url[1] == parentID ) { - $( this ).addClass( 'current' ); - $( this ).parent().addClass( 'current' ); - } - } - ); - - if ( el.find( '#' + oldid + '_section_group_li' ).find( '#' + oldid + '_section_group_li' ).length ) { - //console.log('RELID is child of oldid'); - el.find( '#' + oldid + '_section_group_li' ).addClass( 'activeChild' ); - el.find( '#' + relid + '_section_group_li' ).addClass( 'active' ).removeClass( 'activeChild' ); - } else if ( el.find( '#' + relid + '_section_group_li' ).parents( '#' + oldid + '_section_group_li' ).length || el.find( '#' + oldid + '_section_group_li' ).parents( 'ul.subsection' ).find( '#' + relid + '_section_group_li' ).length ) { - //console.log('RELID is sibling or child of OLDID'); - if ( el.find( '#' + relid + '_section_group_li' ).parents( '#' + oldid + '_section_group_li' ).length ) { - //console.log('child of oldid'); - el.find( '#' + oldid + '_section_group_li' ).addClass( 'activeChild' ).removeClass( 'active' ); - } else { - //console.log('sibling'); - el.find( '#' + relid + '_section_group_li' ).addClass( 'active' ); - el.find( '#' + oldid + '_section_group_li' ).removeClass( 'active' ); - } - el.find( '#' + relid + '_section_group_li' ).removeClass( 'activeChild' ).addClass( 'active' ); - } else { - el.find( '#' + relid + '_section_group_li' ).addClass( 'active' ).removeClass( 'activeChild' ).find( 'ul.subsection' ).slideDown(); - - if ( el.find( '#' + oldid + '_section_group_li' ).find( 'ul.subsection' ).length ) { - //console.log('oldid is parent'); - //console.log('#' + relid + '_section_group_li'); - - el.find( '#' + oldid + '_section_group_li' ).find( 'ul.subsection' ).slideUp( - 'fast', function() { - el.find( '#' + oldid + '_section_group_li' ).removeClass( 'active' ).removeClass( 'activeChild' ); - } - ); - var newParent = el.find( '#' + relid + '_section_group_li' ).parents( '.hasSubSections:first' ); - - if ( newParent.length > 0 ) { - el.find( '#' + relid + '_section_group_li' ).removeClass( 'active' ); - relid = newParent.find( '.redux-group-tab-link-a:first' ).data( 'rel' ); - //console.log(relid); - if ( newParent.hasClass( 'empty_section' ) ) { - newParent.find( '.subsection li:first' ).addClass( 'active' ); - el.find( '#' + relid + '_section_group_li' ).removeClass( 'active' ).addClass( 'activeChild' ).find( 'ul.subsection' ).slideDown(); - newParent = newParent.find( '.subsection li:first' ); - relid = newParent.find( '.redux-group-tab-link-a:first' ).data( 'rel' ); - //console.log('Empty section, do the next one?'); - } else { - el.find( '#' + relid + '_section_group_li' ).addClass( 'active' ).removeClass( 'activeChild' ).find( 'ul.subsection' ).slideDown(); - } - } - } else if ( el.find( '#' + oldid + '_section_group_li' ).parents( 'ul.subsection' ).length ) { - //console.log('oldid is a child'); - if ( !el.find( '#' + oldid + '_section_group_li' ).parents( '#' + relid + '_section_group_li' ).length ) { - //console.log('oldid is child, but not of relid'); - el.find( '#' + oldid + '_section_group_li' ).parents( 'ul.subsection' ).slideUp( - 'fast', function() { - el.find( '#' + oldid + '_section_group_li' ).removeClass( 'active' ); - el.find( '#' + oldid + '_section_group_li' ).parents( '.redux-group-tab-link-li' ).removeClass( 'active' ).removeClass( 'activeChild' ); - el.find( '#' + relid + '_section_group_li' ).parents( '.redux-group-tab-link-li' ).addClass( 'activeChild' ).find( 'ul.subsection' ).slideDown(); - el.find( '#' + relid + '_section_group_li' ).addClass( 'active' ); - } - ); - } else { - //console.log('oldid is child, but not of relid2'); - el.find( '#' + oldid + '_section_group_li' ).removeClass( 'active' ); - } - } else { - //console.log('Normal remove active from child'); - el.find( '#' + oldid + '_section_group_li' ).removeClass( 'active' ); - if ( el.find( '#' + relid + '_section_group_li' ).parents( '.redux-group-tab-link-li' ).length ) { - //console.log('here'); - el.find( '#' + relid + '_section_group_li' ).parents( '.redux-group-tab-link-li' ).addClass( 'activeChild' ).find( 'ul.subsection' ).slideDown(); - el.find( '#' + relid + '_section_group_li' ).addClass( 'active' ); - } - } - } - - // Show the group - el.find( '#' + oldid + '_section_group' ).hide(); - - el.find( '#' + relid + '_section_group' ).fadeIn( - 200, function() { - if ( el.find( '#redux-footer' ).length !== 0 ) { - $.redux.stickyInfo(); // race condition fix - } - $.redux.initFields(); - } - ); - $( '#toplevel_page_' + redux.args.slug ).find( '.current' ).removeClass( 'current' ); - - } - ); - - var tab = decodeURI( (new RegExp( 'tab' + '=' + '(.+?)(&|$)' ).exec( location.search ) || [, ''])[1] ); - - if ( tab !== "" ) { - if ( $.cookie( "redux_current_tab_get" ) !== tab ) { - $.cookie( - 'redux_current_tab', tab, { - expires: 7, - path: '/' - } - ); - $.cookie( - 'redux_current_tab_get', tab, { - expires: 7, - path: '/' - } - ); - - $( '#' + tab + '_section_group_li' ).click(); - } - } else if ( $.cookie( 'redux_current_tab_get' ) !== "" ) { - $.removeCookie( 'redux_current_tab_get' ); - } - - var sTab = $( '#' + $.cookie( "redux_current_tab" ) + '_section_group_li_a' ); - - // Tab the first item or the saved one - if ( $.cookie( "redux_current_tab" ) === null || typeof ($.cookie( "redux_current_tab" )) === "undefined" || sTab.length === 0 ) { - $( '.redux-container' ).find( '.redux-group-tab-link-a:first' ).click(); - } else { - sTab.click(); - } - - }; - - $.redux.initFields = function() { - $( ".redux-group-tab:visible" ).find( ".redux-field-init:visible" ).each( - function() { - - var type = $( this ).attr( 'data-type' ); - //console.log(type); - if ( typeof redux.field_objects != 'undefined' && redux.field_objects[type] && redux.field_objects[type] ) { - redux.field_objects[type].init(); - } - if ( !redux.customizer && $( this ).hasClass( 'redux_remove_th' ) ) { - - var tr = $( this ).parents( 'tr:first' ); - var th = tr.find( 'th:first' ); - if ( th.html() && th.html().length > 0 ) { - $( this ).prepend( th.html() ); - $( this ).find( '.redux_field_th' ).css( 'padding', '0 0 10px 0' ); - } - $( this ).parent().attr( 'colspan', '2' ); - th.remove(); - } - } - ); - }; - - $.redux.notices = function() { - if ( redux.errors && redux.errors.errors ) { - $.each( - redux.errors.errors, function( sectionID, sectionArray ) { - $.each( - sectionArray.errors, function( key, value ) { - $( "#" + redux.args.opt_name + '-' + value.id ).addClass( "redux-field-error" ); - if ( $( "#" + redux.args.opt_name + '-' + value.id ).parent().find( '.redux-th-error' ).length === 0 ) { - $( "#" + redux.args.opt_name + '-' + value.id ).append( '
' + value.msg + '
' ); - } else { - $( "#" + redux.args.opt_name + '-' + value.id ).parent().find( '.redux-th-error' ).html( value.msg ).css( - 'display', 'block' - ); - } - } - ); - } - ); - $( '.redux-container' ).each( - function() { - var container = $( this ); - // Ajax cleanup - container.find( '.redux-menu-error' ).remove(); - var totalErrors = container.find( '.redux-field-error' ).length; - if ( totalErrors > 0 ) { - container.find( ".redux-field-errors span" ).text( totalErrors ); - container.find( ".redux-field-errors" ).slideDown(); - container.find( '.redux-group-tab' ).each( - function() { - var total = $( this ).find( '.redux-field-error' ).length; - if ( total > 0 ) { - var sectionID = $( this ).attr( 'id' ).split( '_' ); - sectionID = sectionID[0]; - container.find( '.redux-group-tab-link-a[data-key="' + sectionID + '"]' ).prepend( '' + total + '' ); - container.find( '.redux-group-tab-link-a[data-key="' + sectionID + '"]' ).addClass( "hasError" ); - var subParent = container.find( '.redux-group-tab-link-a[data-key="' + sectionID + '"]' ).parents( '.hasSubSections:first' ); - if ( subParent ) { - subParent.find( '.redux-group-tab-link-a:first' ).addClass( 'hasError' ); - } - } - } - ); - } - } - ); - } - if ( redux.warnings && redux.warnings.warnings ) { - $.each( - redux.warnings.warnings, function( sectionID, sectionArray ) { - $.each( - sectionArray.warnings, function( key, value ) { - $( "#" + redux.args.opt_name + '-' + value.id ).addClass( "redux-field-warning" ); - if ( $( "#" + redux.args.opt_name + '-' + value.id ).parent().find( '.redux-th-warning' ).length === 0 ) { - $( "#" + redux.args.opt_name + '-' + value.id ).append( '
' + value.msg + '
' ); - } else { - $( "#" + redux.args.opt_name + '-' + value.id ).parent().find( '.redux-th-warning' ).html( value.msg ).css( - 'display', 'block' - ); - } - } - ); - } - ); - $( '.redux-container' ).each( - function() { - var container = $( this ); - // Ajax cleanup - container.find( '.redux-menu-warning' ).remove(); - var totalWarnings = container.find( '.redux-field-warning' ).length; - if ( totalWarnings > 0 ) { - container.find( ".redux-field-warnings span" ).text( totalWarnings ); - container.find( ".redux-field-warnings" ).slideDown(); - container.find( '.redux-group-tab' ).each( - function() { - var total = $( this ).find( '.redux-field-warning' ).length; - if ( total > 0 ) { - var sectionID = $( this ).attr( 'id' ).split( '_' ); - sectionID = sectionID[0]; - container.find( '.redux-group-tab-link-a[data-key="' + sectionID + '"]' ).prepend( '' + total + '' ); - container.find( '.redux-group-tab-link-a[data-key="' + sectionID + '"]' ).addClass( "hasWarning" ); - var subParent = container.find( '.redux-group-tab-link-a[data-key="' + sectionID + '"]' ).parents( '.hasSubSections:first' ); - if ( subParent ) { - subParent.find( '.redux-group-tab-link-a:first' ).addClass( 'hasWarning' ); - } - } - } - ); - } - } - ); - } - }; - - $.redux.tabControl = function() { - $( '.redux-section-tabs div' ).hide(); - $( '.redux-section-tabs div:first' ).show(); - $( '.redux-section-tabs ul li:first' ).addClass( 'active' ); - - $( '.redux-section-tabs ul li a' ).click( - function() { - $( '.redux-section-tabs ul li' ).removeClass( 'active' ); - $( this ).parent().addClass( 'active' ); - - var currentTab = $( this ).attr( 'href' ); - - $( '.redux-section-tabs div' ).hide(); - $( currentTab ).fadeIn( - 'medium', function() { - $.redux.initFields(); - } - ); - - return false; - } - ); - }; - - $.redux.required = function() { - - // Hide the fold elements on load , - // It's better to do this by PHP but there is no filter in tr tag , so is not possible - // we going to move each attributes we may need for folding to tr tag - $.each( - redux.folds, function( i, v ) { - var fieldset = $( '#' + redux.args.opt_name + '-' + i ); - - fieldset.parents( 'tr:first' ).addClass( 'fold' ); - - if ( v == "hide" ) { - fieldset.parents( 'tr:first' ).addClass( 'hide' ); - - if ( fieldset.hasClass( 'redux-container-section' ) ) { - var div = $( '#section-' + i ); - - if ( div.hasClass( 'redux-section-indent-start' ) ) { - $( '#section-table-' + i ).hide().addClass( 'hide' ); - div.hide().addClass( 'hide' ); - } - } - - if ( fieldset.hasClass( 'redux-container-info' ) ) { - $( '#info-' + i ).hide().addClass( 'hide' ); - } - - if ( fieldset.hasClass( 'redux-container-divide' ) ) { - $( '#divide-' + i ).hide().addClass( 'hide' ); - } - - if ( fieldset.hasClass( 'redux-container-raw' ) ) { - var rawTable = fieldset.parents().find( 'table#' + redux.args.opt_name + '-' + i ); - rawTable.hide().addClass( 'hide' ); - } - } - } - ); - }; - - $.redux.get_container_value = function( id ) { - var value = $( '#' + redux.args.opt_name + '-' + id ).serializeForm(); - - if ( value !== null && typeof value === 'object' && value.hasOwnProperty( redux.args.opt_name ) ) { - value = value[redux.args.opt_name][id]; - } - if ( $( '#' + redux.args.opt_name + '-' + id ).hasClass( 'redux-container-media' ) ) { - value = value.url; - } - return value; - }; - - $.redux.check_dependencies = function( variable ) { - if ( redux.required === null ) { - return; - } - var current = $( variable ), - id = current.parents( '.redux-field:first' ).data( 'id' ); - if ( !redux.required.hasOwnProperty( id ) ) { - return; - } - - var container = current.parents( '.redux-field-container:first' ), - is_hidden = container.parents( 'tr:first' ).hasClass( '.hide' ), - hadSections = false; - $.each( - redux.required[id], function( child, dependents ) { - - var current = $( this ), - show = false, - childFieldset = $( '#' + redux.args.opt_name + '-' + child ), - tr = childFieldset.parents( 'tr:first' ); - - if ( !is_hidden ) { - show = $.redux.check_parents_dependencies( child ); - } - - if ( show === true ) { - // Shim for sections - if ( childFieldset.hasClass( 'redux-container-section' ) ) { - var div = $( '#section-' + child ); - - if ( div.hasClass( 'redux-section-indent-start' ) && div.hasClass( 'hide' ) ) { - $( '#section-table-' + child ).fadeIn( 300 ).removeClass( 'hide' ); - div.fadeIn( 300 ).removeClass( 'hide' ); - } - } - - if ( childFieldset.hasClass( 'redux-container-info' ) ) { - $( '#info-' + child ).fadeIn( 300 ).removeClass( 'hide' ); - } - - if ( childFieldset.hasClass( 'redux-container-divide' ) ) { - $( '#divide-' + child ).fadeIn( 300 ).removeClass( 'hide' ); - } - - if ( childFieldset.hasClass( 'redux-container-raw' ) ) { - var rawTable = childFieldset.parents().find( 'table#' + redux.args.opt_name + '-' + child ); - rawTable.fadeIn( 300 ).removeClass( 'hide' ); - } - - tr.fadeIn( - 300, function() { - $( this ).removeClass( 'hide' ); - if ( redux.required.hasOwnProperty( child ) ) { - $.redux.check_dependencies( $( '#' + redux.args.opt_name + '-' + child ).children().first() ); - } - $.redux.initFields(); - } - ); - if ( childFieldset.hasClass( 'redux-container-section' ) || childFieldset.hasClass( 'redux-container-info' ) ) { - tr.css( {display: 'none'} ); - } - } else if ( show === false ) { - tr.fadeOut( - 100, function() { - $( this ).addClass( 'hide' ); - if ( redux.required.hasOwnProperty( child ) ) { - //console.log('Now check, reverse: '+child); - $.redux.required_recursive_hide( child ); - } - } - ); - } - - current.find( 'select, radio, input[type=checkbox]' ).trigger( 'change' ); - } - ); - }; - - $.redux.required_recursive_hide = function( id ) { - var toFade = $( '#' + redux.args.opt_name + '-' + id ).parents( 'tr:first' ); - - toFade.fadeOut( - 50, function() { - $( this ).addClass( 'hide' ); - - if ( $( '#' + redux.args.opt_name + '-' + id ).hasClass( 'redux-container-section' ) ) { - var div = $( '#section-' + id ); - if ( div.hasClass( 'redux-section-indent-start' ) ) { - $( '#section-table-' + id ).fadeOut( 50 ).addClass( 'hide' ); - div.fadeOut( 50 ).addClass( 'hide' ); - } - } - - if ( $( '#' + redux.args.opt_name + '-' + id ).hasClass( 'redux-container-info' ) ) { - $( '#info-' + id ).fadeOut( 50 ).addClass( 'hide' ); - } - - if ( $( '#' + redux.args.opt_name + '-' + id ).hasClass( 'redux-container-divide' ) ) { - $( '#divide-' + id ).fadeOut( 50 ).addClass( 'hide' ); - } - - if ( $( '#' + redux.args.opt_name + '-' + id ).hasClass( 'redux-container-raw' ) ) { - var rawTable = $( '#' + redux.args.opt_name + '-' + id ).parents().find( 'table#' + redux.args.opt_name + '-' + id ); - rawTable.fadeOut( 50 ).addClass( 'hide' ); - } - - if ( redux.required.hasOwnProperty( id ) ) { - $.each( - redux.required[id], function( child ) { - $.redux.required_recursive_hide( child ); - } - ); - } - } - ); - }; - - $.redux.check_parents_dependencies = function( id ) { - var show = ""; - - if ( redux.required_child.hasOwnProperty( id ) ) { - $.each( - redux.required_child[id], function( i, parentData ) { - if ( $( '#' + redux.args.opt_name + '-' + parentData.parent ).parents( 'tr:first' ).hasClass( '.hide' ) ) { - show = false; - } else { - if ( show !== false ) { - var parentValue = $.redux.get_container_value( parentData.parent ); - show = $.redux.check_dependencies_visibility( parentValue, parentData ); - } - } - } - ); - } else { - show = true; - } - return show; - }; - - $.redux.check_dependencies_visibility = function( parentValue, data ) { - var show = false, - checkValue_array, - checkValue = data.checkValue, - operation = data.operation, - arr; - - switch ( operation ) { - case '=': - case 'equals': -// if ($.isPlainObject(parentValue)) { -// var arr = Object.keys(parentValue).map(function (key) {return parentValue[key]}); -// parentValue = arr; -// } - - if ( $.isArray( parentValue ) ) { - $( parentValue[0] ).each( - function( idx, val ) { - if ( $.isArray( checkValue ) ) { - $( checkValue ).each( - function( i, v ) { - if ( val == v ) { - show = true; - return true; - } - } - ); - } else { - if ( val == checkValue ) { - show = true; - return true; - } - } - } - ); - } else { - if ( $.isArray( checkValue ) ) { - $( checkValue ).each( - function( i, v ) { - if ( parentValue == v ) { - show = true; - } - } - ); - } else { - if ( parentValue == checkValue ) { - show = true; - } - } - } - break; - - case '!=': - case 'not': - if ( $.isArray( parentValue ) ) { - $( parentValue ).each( - function( idx, val ) { - if ( $.isArray( checkValue ) ) { - $( checkValue ).each( - function( i, v ) { - if ( val != v ) { - show = true; - return true; - } - } - ); - } else { - if ( val != checkValue ) { - show = true; - return true; - } - } - } - ); - } else { - if ( $.isArray( checkValue ) ) { - $( checkValue ).each( - function( i, v ) { - if ( parentValue != v ) { - show = true; - } - } - ); - } else { - if ( parentValue != checkValue ) { - show = true; - } - } - } - - // //if value was array - // if ( $.isArray( checkValue ) ) { - // if ( $.inArray( parentValue, checkValue ) == -1 ) { - // show = true; - // } - // } else { - // if ( parentValue != checkValue ) { - // show = true; - // } else if ( $.isArray( parentValue ) ) { - // if ( $.inArray( checkValue, parentValue ) == -1 ) { - // show = true; - // } - // } - // } - break; - - case '>': - case 'greater': - case 'is_larger': - if ( parseFloat( parentValue ) > parseFloat( checkValue ) ) { - show = true; - } - break; - - case '>=': - case 'greater_equal': - case 'is_larger_equal': - if ( parseFloat( parentValue ) >= parseFloat( checkValue ) ) { - show = true; - } - break; - - case '<': - case 'less': - case 'is_smaller': - if ( parseFloat( parentValue ) < parseFloat( checkValue ) ) { - show = true; - } - break; - - case '<=': - case 'less_equal': - case 'is_smaller_equal': - if ( parseFloat( parentValue ) <= parseFloat( checkValue ) ) { - show = true; - } - break; - - case 'contains': - if ($.isPlainObject(parentValue)) { - arr = Object.keys(parentValue).map(function (key) { - return parentValue[key]; - }); - parentValue = arr; - } - - if ($.isPlainObject(checkValue)) { - arr = Object.keys(checkValue).map(function (key) { - return checkValue[key]; - }); - checkValue = arr; - } - - if ( $.isArray( checkValue ) ) { - $( checkValue ).each( - function( idx, val ) { - //console.log (val); - if ( parentValue.toString().indexOf( val ) !== -1 ) { - show = true; - } - } - ); - } else { - if ( parentValue.toString().indexOf( checkValue ) !== -1 ) { - show = true; - } - } - break; - - case 'doesnt_contain': - case 'not_contain': - if ($.isPlainObject(parentValue)) { - arr = Object.keys(parentValue).map(function (key) { - return parentValue[key]; - }); - parentValue = arr; - } - - if ($.isPlainObject(checkValue)) { - arr = Object.keys(checkValue).map(function (key) { - return checkValue[key]; - }); - checkValue = arr; - } - - if ( $.isArray( checkValue ) ) { - $( checkValue ).each( - function( idx, val ) { - if ( parentValue.toString().indexOf( val ) === -1 ) { - show = true; - } - } - ); - } else { - if ( parentValue.toString().indexOf( checkValue ) === -1 ) { - show = true; - } - } - break; - - case 'is_empty_or': - if ( parentValue === "" || parentValue == checkValue ) { - show = true; - } - break; - - case 'not_empty_and': - if ( parentValue !== "" && parentValue != checkValue ) { - show = true; - } - break; - - case 'is_empty': - case 'empty': - case '!isset': - if ( !parentValue || parentValue === "" || parentValue === null ) { - show = true; - } - break; - - case 'not_empty': - case '!empty': - case 'isset': - if ( parentValue && parentValue !== "" && parentValue !== null ) { - show = true; - } - break; - } - return show; - - }; - - $.redux.verifyPos = function( s, b ) { - - // trim off spaces - s = s.replace( /^\s+|\s+$/gm, '' ); - - // position value is blank, set the default - if ( s === '' || s.search( ' ' ) == -1 ) { - if ( b === true ) { - return 'top left'; - } else { - return 'bottom right'; - } - } - - // split string into array - var split = s.split( ' ' ); - - // Evaluate first string. Must be top, center, or bottom - var paramOne = b ? 'top' : 'bottom'; - if ( split[0] == 'top' || split[0] == 'center' || split[0] == 'bottom' ) { - paramOne = split[0]; - } - - // Evaluate second string. Must be left, center, or right. - var paramTwo = b ? 'left' : 'right'; - if ( split[1] == 'left' || split[1] == 'center' || split[1] == 'right' ) { - paramTwo = split[1]; - } - - return paramOne + ' ' + paramTwo; - }; - - $.redux.stickyInfo = function() { - var stickyWidth = $( '.redux-main' ).innerWidth() - 20; - - if ( !$( '#info_bar' ).isOnScreen() && !$( '#redux-footer-sticky' ).isOnScreen() ) { - $( '#redux-footer' ).css( - { - position: 'fixed', - bottom: '0', - width: stickyWidth, - right: 21 - } - ); - $( '#redux-footer' ).addClass( 'sticky-footer-fixed' ); - $( '.redux-save-warn' ).css( 'left', $( '#redux-sticky' ).offset().left ); - $( '#redux-sticky-padder' ).show(); - } else { - $( '#redux-footer' ).css( - { - background: '#eee', - position: 'inherit', - bottom: 'inherit', - width: 'inherit' - } - ); - $( '#redux-sticky-padder' ).hide(); - $( '#redux-footer' ).removeClass( 'sticky-footer-fixed' ); - } - if ( !$( '#info_bar' ).isOnScreen() ) { - $( '#redux-sticky' ).addClass( 'sticky-save-warn' ); - } else { - $( '#redux-sticky' ).removeClass( 'sticky-save-warn' ); - } - }; - - $.redux.expandOptions = function( parent ) { - var trigger = parent.find( '.expand_options' ); - var width = parent.find( '.redux-sidebar' ).width() - 1; - var id = $( '.redux-group-menu .active a' ).data( 'rel' ) + '_section_group'; - - if ( trigger.hasClass( 'expanded' ) ) { - trigger.removeClass( 'expanded' ); - parent.find( '.redux-main' ).removeClass( 'expand' ); - - parent.find( '.redux-sidebar' ).stop().animate( - { - 'margin-left': '0px' - }, 500 - ); - - parent.find( '.redux-main' ).stop().animate( - { - 'margin-left': width - }, 500, function() { - parent.find( '.redux-main' ).attr( 'style', '' ); - } - ); - - parent.find( '.redux-group-tab' ).each( - function() { - if ( $( this ).attr( 'id' ) !== id ) { - $( this ).fadeOut( 'fast' ); - } - } - ); - // Show the only active one - } else { - trigger.addClass( 'expanded' ); - parent.find( '.redux-main' ).addClass( 'expand' ); - - parent.find( '.redux-sidebar' ).stop().animate( - { - 'margin-left': -width - 113 - }, 500 - ); - - parent.find( '.redux-main' ).stop().animate( - { - 'margin-left': '-1px' - }, 500 - ); - - parent.find( '.redux-group-tab' ).fadeIn( - 'medium', function() { - $.redux.initFields(); - } - ); - } - return false; - }; - - - $.redux.scaleToRatio = function( el, maxHeight, maxWidth ) { - var ratio = 0; // Used for aspect ratio - - var width = el.attr( 'data-width' ); - if ( !width ) { - width = el.width(); - el.attr( 'data-width', width ); - } - var height = el.attr( 'data-height' ); - var eHeight = el.height(); - if ( !height || eHeight > height ) { - height = eHeight; - el.attr( 'data-height', height ); - el.css( "width", 'auto' ); - el.attr( 'data-width', el.width() ); - width = el.width(); - } - - - // Check if the current width is larger than the max - if ( width > maxWidth ) { - ratio = maxWidth / width; // get ratio for scaling image - el.css( "width", maxWidth ); // Set new width - el.css( "height", height * ratio ); // Scale height based on ratio - height = height * ratio; // Reset height to match scaled image - width = width * ratio; // Reset width to match scaled image - - } else { - el.css( "width", 'auto' ); // Set new height - - } - - // Check if current height is larger than max - if ( height > maxHeight ) { - ratio = maxHeight / height; // get ratio for scaling image - el.css( "height", maxHeight ); // Set new height - el.css( "width", width * ratio ); // Scale width based on ratio - width = width * ratio; // Reset width to match scaled image - height = height * ratio; // Reset height to match scaled image - - - } else { - el.css( "height", 'auto' ); // Set new height - - } - - var test = ($( document.getElementById( 'redux-header' ) ).height() - el.height()) / 2; - if ( test > 0 ) { - el.css( "margin-top", test ); - } else { - el.css( "margin-top", 0 ); - } - - if ( $( '#redux-header .redux_field_search' ) ) { - $( '#redux-header .redux_field_search' ).css( 'right', ($( el ).width() + 20) ); - } - - - }; - $.redux.resizeAds = function() { - var el = $( '#redux-header' ); - var maxWidth; - if ( el.length ) { - maxWidth = el.width() - el.find( '.display_header' ).width() - 30; - } else { - el = $( '#customize-info' ); - maxWidth = el.width(); - } - - var maxHeight = el.height(); - var rAds = el.find( '.rAds' ); - - $( rAds ).find( 'video' ).each( - function() { - $.redux.scaleToRatio( $( this ), maxHeight, maxWidth ); - } - ); - $( rAds ).find( 'img' ).each( - function() { - $.redux.scaleToRatio( $( this ), maxHeight, maxWidth ); - } - ); - $( rAds ).find( 'div' ).each( - function() { - $.redux.scaleToRatio( $( this ), maxHeight, maxWidth ); - } - ); - - if ( rAds.css( 'left' ) == "-99999px" ) { - rAds.css( 'display', 'none' ).css( 'left', 'auto' ); - } - rAds.fadeIn( 'slow' ); - }; - $( document ).ready( - function() { - if ( redux.rAds ) { - setTimeout( - function() { - var el; - if ( $( '#redux-header' ).length > 0 ) { - $( '#redux-header' ).append( '
' ); - el = $( '#redux-header' ); - } else { - $('#customize-theme-controls ul').first().prepend('
  • '); - el = $( '#redux_rAds' ); - } - - el.css( 'position', 'relative' ); - - el.find( '.rAds' ).attr( - 'style', - 'position:absolute; top: 6px; right: 6px; display:block !important;overflow:hidden;' - ).css( 'left', '-99999px' ); - el.find( '.rAds' ).html( redux.rAds.replace( //, '' ) ); - var rAds = el.find( '.rAds' ); - - var maxHeight = el.height(); - var maxWidth = el.width() - el.find( '.display_header' ).width() - 30; - - rAds.find( 'a' ).css( 'float', 'right' ).css( 'line-height', el.height() + 'px' ).css( - 'margin-left', '5px' - ); - - $( document ).ajaxComplete( - function() { - rAds.find( 'a' ).hide(); - setTimeout( - function() { - $.redux.resizeAds(); - rAds.find( 'a' ).fadeIn(); - }, 1400 - ); - setTimeout( - function() { - $.redux.resizeAds(); - - }, 1500 - ); - $( document ).unbind( 'ajaxComplete' ); - } - ); - - $( window ).resize( - function() { - $.redux.resizeAds(); - } - ); - }, 400 - ); - - } - } - ); -})( jQuery ); - -jQuery.noConflict(); - -var confirmOnPageExit = function( e ) { - //return; // ONLY FOR DEBUGGING - // If we haven't been passed the event get the window.event - e = e || window.event; - - var message = redux.args.save_pending; - - // For IE6-8 and Firefox prior to version 4 - if ( e ) { - e.returnValue = message; - } - - window.onbeforeunload = null; - - // For Chrome, Safari, IE8+ and Opera 12+ - return message; -}; - -function redux_change( variable ) { - - jQuery( 'body' ).trigger( 'check_dependencies', variable ); - - if ( variable.hasClass( 'compiler' ) ) { - jQuery( '#redux-compiler-hook' ).val( 1 ); - } - - var rContainer = jQuery( variable ).parents( '.redux-container:first' ); - var parentID = jQuery( variable ).closest( '.redux-group-tab' ).attr( 'id' ); - // Let's count down the errors now. Fancy. ;) - var id = parentID.split( '_' ); - id = id[0]; - - var th = rContainer.find( '.redux-group-tab-link-a[data-key="' + id + '"]' ).parents( '.redux-group-tab-link-li:first' ); - var subParent = jQuery( '#' + parentID + '_li' ).parents( '.hasSubSections:first' ); - - if ( jQuery( variable ).parents( 'fieldset.redux-field:first' ).hasClass( 'redux-field-error' ) ) { - jQuery( variable ).parents( 'fieldset.redux-field:first' ).removeClass( 'redux-field-error' ); - jQuery( variable ).parent().find( '.redux-th-error' ).slideUp(); - - var errorCount = (parseInt( rContainer.find( '.redux-field-errors span' ).text() ) - 1); - - if ( errorCount <= 0 ) { - //console.log('HERE'); - jQuery( '#' + parentID + '_li .redux-menu-error' ).fadeOut( 'fast' ).remove(); - jQuery( '#' + parentID + '_li .redux-group-tab-link-a' ).removeClass( 'hasError' ); - - jQuery( '#' + parentID + '_li' ).parents( '.inside:first' ).find( '.redux-field-errors' ).slideUp(); - jQuery( variable ).parents( '.redux-container:first' ).find( '.redux-field-errors' ).slideUp(); - jQuery( '#redux_metaboxes_errors' ).slideUp(); - } else { - - var errorsLeft = (parseInt( th.find( '.redux-menu-error:first' ).text() ) - 1); - if ( errorsLeft <= 0 ) { - th.find( '.redux-menu-error:first' ).fadeOut().remove(); - } else { - th.find( '.redux-menu-error:first' ).text( errorsLeft ); - } - - rContainer.find( '.redux-field-errors span' ).text( errorCount ); - } - - if ( subParent.length !== 0 ) { - if ( subParent.find( '.redux-menu-error' ).length === 0 ) { - subParent.find( '.hasError' ).removeClass( 'hasError' ); - } - } - } - if ( jQuery( variable ).parents( 'fieldset.redux-field:first' ).hasClass( 'redux-field-warning' ) ) { - jQuery( variable ).parents( 'fieldset.redux-field:first' ).removeClass( 'redux-field-warning' ); - jQuery( variable ).parent().find( '.redux-th-warning' ).slideUp(); - - var warningCount = (parseInt( rContainer.find( '.redux-field-warnings span' ).text() ) - 1); - - if ( warningCount <= 0 ) { - //console.log('HERE'); - jQuery( '#' + parentID + '_li .redux-menu-warning' ).fadeOut( 'fast' ).remove(); - jQuery( '#' + parentID + '_li .redux-group-tab-link-a' ).removeClass( 'hasWarning' ); - - jQuery( '#' + parentID + '_li' ).parents( '.inside:first' ).find( '.redux-field-warnings' ).slideUp(); - jQuery( variable ).parents( '.redux-container:first' ).find( '.redux-field-warnings' ).slideUp(); - jQuery( '#redux_metaboxes_warnings' ).slideUp(); - } else { - // Let's count down the warnings now. Fancy. ;) - - var warningsLeft = (parseInt( th.find( '.redux-menu-warning:first' ).text() ) - 1); - if ( warningsLeft <= 0 ) { - th.find( '.redux-menu-warning:first' ).fadeOut().remove(); - } else { - th.find( '.redux-menu-warning:first' ).text( warningsLeft ); - } - - rContainer.find( '.redux-field-warning span' ).text( warningCount ); - - } - if ( subParent.length !== 0 ) { - if ( subParent.find( '.redux-menu-warning' ).length === 0 ) { - subParent.find( '.hasWarning' ).removeClass( 'hasWarning' ); - } - } - } - // Don't show the changed value notice while save_notice is visible. - if ( rContainer.find( '.saved_notice:visible' ).length > 0 ) { - return; - } - - - if ( redux.customizer ) { - redux.customizer.save( variable, rContainer, parentID ); - return; - } - - if ( !redux.args.disable_save_warn ) { - rContainer.find( '.redux-save-warn' ).slideDown(); - window.onbeforeunload = confirmOnPageExit; - } -} - -function colorValidate( field ) { - var value = jQuery( field ).val(); - - var hex = colorNameToHex( value ); - if ( hex !== value.replace( '#', '' ) ) { - return hex; - } - - return value; -} - -function colorNameToHex( colour ) { - var tcolour = colour.replace( /^\s\s*/, '' ).replace( /\s\s*$/, '' ).replace( "#", "" ); - - var colours = { - "aliceblue": "#f0f8ff", - "antiquewhite": "#faebd7", - "aqua": "#00ffff", - "aquamarine": "#7fffd4", - "azure": "#f0ffff", - "beige": "#f5f5dc", - "bisque": "#ffe4c4", - "black": "#000000", - "blanchedalmond": "#ffebcd", - "blue": "#0000ff", - "blueviolet": "#8a2be2", - "brown": "#a52a2a", - "burlywood": "#deb887", - "cadetblue": "#5f9ea0", - "chartreuse": "#7fff00", - "chocolate": "#d2691e", - "coral": "#ff7f50", - "cornflowerblue": "#6495ed", - "cornsilk": "#fff8dc", - "crimson": "#dc143c", - "cyan": "#00ffff", - "darkblue": "#00008b", - "darkcyan": "#008b8b", - "darkgoldenrod": "#b8860b", - "darkgray": "#a9a9a9", - "darkgreen": "#006400", - "darkkhaki": "#bdb76b", - "darkmagenta": "#8b008b", - "darkolivegreen": "#556b2f", - "darkorange": "#ff8c00", - "darkorchid": "#9932cc", - "darkred": "#8b0000", - "darksalmon": "#e9967a", - "darkseagreen": "#8fbc8f", - "darkslateblue": "#483d8b", - "darkslategray": "#2f4f4f", - "darkturquoise": "#00ced1", - "darkviolet": "#9400d3", - "deeppink": "#ff1493", - "deepskyblue": "#00bfff", - "dimgray": "#696969", - "dodgerblue": "#1e90ff", - "firebrick": "#b22222", - "floralwhite": "#fffaf0", - "forestgreen": "#228b22", - "fuchsia": "#ff00ff", - "gainsboro": "#dcdcdc", - "ghostwhite": "#f8f8ff", - "gold": "#ffd700", - "goldenrod": "#daa520", - "gray": "#808080", - "green": "#008000", - "greenyellow": "#adff2f", - "honeydew": "#f0fff0", - "hotpink": "#ff69b4", - "indianred ": "#cd5c5c", - "indigo ": "#4b0082", - "ivory": "#fffff0", - "khaki": "#f0e68c", - "lavender": "#e6e6fa", - "lavenderblush": "#fff0f5", - "lawngreen": "#7cfc00", - "lemonchiffon": "#fffacd", - "lightblue": "#add8e6", - "lightcoral": "#f08080", - "lightcyan": "#e0ffff", - "lightgoldenrodyellow": "#fafad2", - "lightgrey": "#d3d3d3", - "lightgreen": "#90ee90", - "lightpink": "#ffb6c1", - "lightsalmon": "#ffa07a", - "lightseagreen": "#20b2aa", - "lightskyblue": "#87cefa", - "lightslategray": "#778899", - "lightsteelblue": "#b0c4de", - "lightyellow": "#ffffe0", - "lime": "#00ff00", - "limegreen": "#32cd32", - "linen": "#faf0e6", - "magenta": "#ff00ff", - "maroon": "#800000", - "mediumaquamarine": "#66cdaa", - "mediumblue": "#0000cd", - "mediumorchid": "#ba55d3", - "mediumpurple": "#9370d8", - "mediumseagreen": "#3cb371", - "mediumslateblue": "#7b68ee", - "mediumspringgreen": "#00fa9a", - "mediumturquoise": "#48d1cc", - "mediumvioletred": "#c71585", - "midnightblue": "#191970", - "mintcream": "#f5fffa", - "mistyrose": "#ffe4e1", - "moccasin": "#ffe4b5", - "navajowhite": "#ffdead", - "navy": "#000080", - "oldlace": "#fdf5e6", - "olive": "#808000", - "olivedrab": "#6b8e23", - "orange": "#ffa500", - "orangered": "#ff4500", - "orchid": "#da70d6", - "palegoldenrod": "#eee8aa", - "palegreen": "#98fb98", - "paleturquoise": "#afeeee", - "palevioletred": "#d87093", - "papayawhip": "#ffefd5", - "peachpuff": "#ffdab9", - "peru": "#cd853f", - "pink": "#ffc0cb", - "plum": "#dda0dd", - "powderblue": "#b0e0e6", - "purple": "#800080", - "red": "#ff0000", - "redux": "#01a3e3", - "rosybrown": "#bc8f8f", - "royalblue": "#4169e1", - "saddlebrown": "#8b4513", - "salmon": "#fa8072", - "sandybrown": "#f4a460", - "seagreen": "#2e8b57", - "seashell": "#fff5ee", - "sienna": "#a0522d", - "silver": "#c0c0c0", - "skyblue": "#87ceeb", - "slateblue": "#6a5acd", - "slategray": "#708090", - "snow": "#fffafa", - "springgreen": "#00ff7f", - "steelblue": "#4682b4", - "tan": "#d2b48c", - "teal": "#008080", - "thistle": "#d8bfd8", - "tomato": "#ff6347", - "turquoise": "#40e0d0", - "violet": "#ee82ee", - "wheat": "#f5deb3", - "white": "#ffffff", - "whitesmoke": "#f5f5f5", - "yellow": "#ffff00", - "yellowgreen": "#9acd32" - }; - - if ( colours[tcolour.toLowerCase()] !== 'undefined' ) { - return colours[tcolour.toLowerCase()]; - } - - return colour; -} - diff --git a/library/admin/ReduxCore/assets/js/redux.min.js b/library/admin/ReduxCore/assets/js/redux.min.js deleted file mode 100644 index 65dfe719..00000000 --- a/library/admin/ReduxCore/assets/js/redux.min.js +++ /dev/null @@ -1,2 +0,0 @@ -function redux_change(a){jQuery("body").trigger("check_dependencies",a),a.hasClass("compiler")&&jQuery("#redux-compiler-hook").val(1);var b=jQuery(a).parents(".redux-container:first"),c=jQuery(a).closest(".redux-group-tab").attr("id"),d=c.split("_");d=d[0];var e=b.find('.redux-group-tab-link-a[data-key="'+d+'"]').parents(".redux-group-tab-link-li:first"),f=jQuery("#"+c+"_li").parents(".hasSubSections:first");if(jQuery(a).parents("fieldset.redux-field:first").hasClass("redux-field-error")){jQuery(a).parents("fieldset.redux-field:first").removeClass("redux-field-error"),jQuery(a).parent().find(".redux-th-error").slideUp();var g=parseInt(b.find(".redux-field-errors span").text())-1;if(0>=g)jQuery("#"+c+"_li .redux-menu-error").fadeOut("fast").remove(),jQuery("#"+c+"_li .redux-group-tab-link-a").removeClass("hasError"),jQuery("#"+c+"_li").parents(".inside:first").find(".redux-field-errors").slideUp(),jQuery(a).parents(".redux-container:first").find(".redux-field-errors").slideUp(),jQuery("#redux_metaboxes_errors").slideUp();else{var h=parseInt(e.find(".redux-menu-error:first").text())-1;0>=h?e.find(".redux-menu-error:first").fadeOut().remove():e.find(".redux-menu-error:first").text(h),b.find(".redux-field-errors span").text(g)}0!==f.length&&0===f.find(".redux-menu-error").length&&f.find(".hasError").removeClass("hasError")}if(jQuery(a).parents("fieldset.redux-field:first").hasClass("redux-field-warning")){jQuery(a).parents("fieldset.redux-field:first").removeClass("redux-field-warning"),jQuery(a).parent().find(".redux-th-warning").slideUp();var i=parseInt(b.find(".redux-field-warnings span").text())-1;if(0>=i)jQuery("#"+c+"_li .redux-menu-warning").fadeOut("fast").remove(),jQuery("#"+c+"_li .redux-group-tab-link-a").removeClass("hasWarning"),jQuery("#"+c+"_li").parents(".inside:first").find(".redux-field-warnings").slideUp(),jQuery(a).parents(".redux-container:first").find(".redux-field-warnings").slideUp(),jQuery("#redux_metaboxes_warnings").slideUp();else{var j=parseInt(e.find(".redux-menu-warning:first").text())-1;0>=j?e.find(".redux-menu-warning:first").fadeOut().remove():e.find(".redux-menu-warning:first").text(j),b.find(".redux-field-warning span").text(i)}0!==f.length&&0===f.find(".redux-menu-warning").length&&f.find(".hasWarning").removeClass("hasWarning")}return b.find(".saved_notice:visible").length>0?void 0:redux.customizer?void redux.customizer.save(a,b,c):void(redux.args.disable_save_warn||(b.find(".redux-save-warn").slideDown(),window.onbeforeunload=confirmOnPageExit))}function colorValidate(a){var b=jQuery(a).val(),c=colorNameToHex(b);return c!==b.replace("#","")?c:b}function colorNameToHex(a){var b=a.replace(/^\s\s*/,"").replace(/\s\s*$/,"").replace("#",""),c={aliceblue:"#f0f8ff",antiquewhite:"#faebd7",aqua:"#00ffff",aquamarine:"#7fffd4",azure:"#f0ffff",beige:"#f5f5dc",bisque:"#ffe4c4",black:"#000000",blanchedalmond:"#ffebcd",blue:"#0000ff",blueviolet:"#8a2be2",brown:"#a52a2a",burlywood:"#deb887",cadetblue:"#5f9ea0",chartreuse:"#7fff00",chocolate:"#d2691e",coral:"#ff7f50",cornflowerblue:"#6495ed",cornsilk:"#fff8dc",crimson:"#dc143c",cyan:"#00ffff",darkblue:"#00008b",darkcyan:"#008b8b",darkgoldenrod:"#b8860b",darkgray:"#a9a9a9",darkgreen:"#006400",darkkhaki:"#bdb76b",darkmagenta:"#8b008b",darkolivegreen:"#556b2f",darkorange:"#ff8c00",darkorchid:"#9932cc",darkred:"#8b0000",darksalmon:"#e9967a",darkseagreen:"#8fbc8f",darkslateblue:"#483d8b",darkslategray:"#2f4f4f",darkturquoise:"#00ced1",darkviolet:"#9400d3",deeppink:"#ff1493",deepskyblue:"#00bfff",dimgray:"#696969",dodgerblue:"#1e90ff",firebrick:"#b22222",floralwhite:"#fffaf0",forestgreen:"#228b22",fuchsia:"#ff00ff",gainsboro:"#dcdcdc",ghostwhite:"#f8f8ff",gold:"#ffd700",goldenrod:"#daa520",gray:"#808080",green:"#008000",greenyellow:"#adff2f",honeydew:"#f0fff0",hotpink:"#ff69b4","indianred ":"#cd5c5c","indigo ":"#4b0082",ivory:"#fffff0",khaki:"#f0e68c",lavender:"#e6e6fa",lavenderblush:"#fff0f5",lawngreen:"#7cfc00",lemonchiffon:"#fffacd",lightblue:"#add8e6",lightcoral:"#f08080",lightcyan:"#e0ffff",lightgoldenrodyellow:"#fafad2",lightgrey:"#d3d3d3",lightgreen:"#90ee90",lightpink:"#ffb6c1",lightsalmon:"#ffa07a",lightseagreen:"#20b2aa",lightskyblue:"#87cefa",lightslategray:"#778899",lightsteelblue:"#b0c4de",lightyellow:"#ffffe0",lime:"#00ff00",limegreen:"#32cd32",linen:"#faf0e6",magenta:"#ff00ff",maroon:"#800000",mediumaquamarine:"#66cdaa",mediumblue:"#0000cd",mediumorchid:"#ba55d3",mediumpurple:"#9370d8",mediumseagreen:"#3cb371",mediumslateblue:"#7b68ee",mediumspringgreen:"#00fa9a",mediumturquoise:"#48d1cc",mediumvioletred:"#c71585",midnightblue:"#191970",mintcream:"#f5fffa",mistyrose:"#ffe4e1",moccasin:"#ffe4b5",navajowhite:"#ffdead",navy:"#000080",oldlace:"#fdf5e6",olive:"#808000",olivedrab:"#6b8e23",orange:"#ffa500",orangered:"#ff4500",orchid:"#da70d6",palegoldenrod:"#eee8aa",palegreen:"#98fb98",paleturquoise:"#afeeee",palevioletred:"#d87093",papayawhip:"#ffefd5",peachpuff:"#ffdab9",peru:"#cd853f",pink:"#ffc0cb",plum:"#dda0dd",powderblue:"#b0e0e6",purple:"#800080",red:"#ff0000",redux:"#01a3e3",rosybrown:"#bc8f8f",royalblue:"#4169e1",saddlebrown:"#8b4513",salmon:"#fa8072",sandybrown:"#f4a460",seagreen:"#2e8b57",seashell:"#fff5ee",sienna:"#a0522d",silver:"#c0c0c0",skyblue:"#87ceeb",slateblue:"#6a5acd",slategray:"#708090",snow:"#fffafa",springgreen:"#00ff7f",steelblue:"#4682b4",tan:"#d2b48c",teal:"#008080",thistle:"#d8bfd8",tomato:"#ff6347",turquoise:"#40e0d0",violet:"#ee82ee",wheat:"#f5deb3",white:"#ffffff",whitesmoke:"#f5f5f5",yellow:"#ffff00",yellowgreen:"#9acd32"};return"undefined"!==c[b.toLowerCase()]?c[b.toLowerCase()]:a}!function(a){"function"==typeof define&&define.amd?jQueryCookie.define(["jquery"],a):a(jQuery)}(function(a){function b(a){return a}function c(a){return decodeURIComponent(a.replace(e," "))}function d(a){0===a.indexOf('"')&&(a=a.slice(1,-1).replace(/\\"/g,'"').replace(/\\\\/g,"\\"));try{return f.json?JSON.parse(a):a}catch(b){}}var e=/\+/g,f=a.cookie=function(e,g,h){if(void 0!==g){if(h=a.extend({},f.defaults,h),"number"==typeof h.expires){var i=h.expires,j=h.expires=new Date;j.setDate(j.getDate()+i)}return g=f.json?JSON.stringify(g):String(g),document.cookie=[f.raw?e:encodeURIComponent(e),"=",f.raw?g:encodeURIComponent(g),h.expires?"; expires="+h.expires.toUTCString():"",h.path?"; path="+h.path:"",h.domain?"; domain="+h.domain:"",h.secure?"; secure":""].join("")}for(var k=f.raw?b:c,l=document.cookie.split("; "),m=e?void 0:{},n=0,o=l.length;o>n;n++){var p=l[n].split("="),q=k(p.shift()),r=k(p.join("="));if(e&&e===q){m=d(r);break}e||(m[q]=d(r))}return m};f.defaults={},a.removeCookie=function(b,c){return void 0!==a.cookie(b)?(a.cookie(b,"",a.extend({},c,{expires:-1})),!0):!1}}),function(a){a.fn.typeWatch=function(b){function c(b,c){var d=a(b.el).val();(d.length>=f.captureLength&&d.toUpperCase()!=b.text||c&&d.length>=f.captureLength)&&(b.text=d.toUpperCase(),b.cb.call(b.el,d))}function d(b){var d=b.type.toUpperCase();if(a.inArray(d,f.inputTypes)>=0){var e={timer:null,text:a(b).val().toUpperCase(),cb:f.callback,el:b,wait:f.wait};f.highlight&&a(b).focus(function(){this.select()});var g=function(b){var d=e.wait,g=!1,h=this.type.toUpperCase();"undefined"!=typeof b.keyCode&&13==b.keyCode&&"TEXTAREA"!=h&&a.inArray(h,f.inputTypes)>=0&&(d=1,g=!0);var i=function(){c(e,g)};clearTimeout(e.timer),e.timer=setTimeout(i,d)};a(b).on("keydown paste cut input",g)}}var e=["TEXT","TEXTAREA","PASSWORD","TEL","SEARCH","URL","EMAIL","DATETIME","DATE","MONTH","WEEK","TIME","DATETIME-LOCAL","NUMBER","RANGE"],f=a.extend({wait:750,callback:function(){},highlight:!0,captureLength:2,inputTypes:e},b);return this.each(function(){d(this)})}}(jQuery),function(a){a.fn.serializeForm=function(){if(this.length<1)return!1;var b={},c=b,d=':input[type!="checkbox"][type!="radio"], input:checked',e=function(){if(!this.disabled){var d=this.name.replace(/\[([^\]]+)?\]/g,",$1").split(","),e=d.length-1,f=a(this);if(d[0]){for(var g=0;e>g;g++)c=c[d[g]]=c[d[g]]||(""===d[g+1]||"0"===d[g+1]?[]:{});void 0!==c.length?c.push(f.val()):c[d[e]]=f.val(),c=b}}};return this.filter(d).each(e),this.find(d).each(e),b}}(jQuery),function(a){function b(){var a="!@#$%^&*()+=[]\\';,/{}|\":<>?~`.-_";return a+=" "}function c(){var a="¬€£¦";return a}function d(b,c,d){b.each(function(){var b=a(this);b.bind("keyup change paste",function(a){var e="";a.originalEvent&&a.originalEvent.clipboardData&&a.originalEvent.clipboardData.getData&&(e=a.originalEvent.clipboardData.getData("text/plain")),setTimeout(function(){h(b,c,d,e)},0)}),b.bind("keypress",function(a){var e=a.charCode?a.charCode:a.which;if(!(g(e)||a.ctrlKey||a.metaKey)){var f=String.fromCharCode(e),h=b.selection(),i=h.start,j=h.end,k=b.val(),l=k.substring(0,i)+f+k.substring(j),m=c(l,d);m!=l&&a.preventDefault()}})})}function e(b,c){var d=parseFloat(a(b).val()),e=a(b);return isNaN(d)?void e.val(""):(f(c.min)&&dc.max&&e.val("")))}function f(a){return!isNaN(a)}function g(a){return a>=32?!1:10==a?!1:13==a?!1:!0}function h(a,b,c,d){var e=a.val();""==e&&d.length>0&&(e=d);var f=b(e,c);if(e!=f){var g=a.alphanum_caret();a.val(f),e.length==f.length+1?a.alphanum_caret(g-1):a.alphanum_caret(g)}}function i(b,c){"undefined"==typeof c&&(c=D);var d,e={};return d="string"==typeof b?F[b]:"undefined"==typeof b?{}:b,a.extend(e,c,d),"undefined"==typeof e.blacklist&&(e.blacklistSet=x(e.allow,e.disallow)),e}function j(b){var c,d={};return c="string"==typeof b?G[b]:"undefined"==typeof b?{}:b,a.extend(d,E,c),d}function k(a,b,c){return c.maxLength&&a.length>=c.maxLength?!1:c.allow.indexOf(b)>=0?!0:c.allowSpace&&" "==b?!0:c.blacklistSet.contains(b)?!1:!c.allowNumeric&&K[b]?!1:!c.allowUpper&&u(b)?!1:!c.allowLower&&v(b)?!1:!c.allowCaseless&&w(b)?!1:!c.allowLatin&&L.contains(b)?!1:c.allowOtherCharSets?!0:K[b]||L.contains(b)?!0:!1}function l(a,b,c){if(K[b])return n(a,c)?!1:p(a,c)?!1:o(a,c)?!1:q(a+b,c)?!1:r(a+b,c)?!1:!0;if(c.allowPlus&&"+"==b&&""==a)return!0;if(c.allowMinus&&"-"==b&&""==a)return!0;if(b==I&&c.allowThouSep&&A(a,b))return!0;if(b==J){if(a.indexOf(J)>=0)return!1;if(c.allowDecSep)return!0}return!1}function m(a){return a+="",a.replace(/[^0-9]/g,"").length}function n(a,b){var c=b.maxDigits;if(""==c||isNaN(c))return!1;var d=m(a);return d>=c?!0:!1}function o(a,b){var c=b.maxDecimalPlaces;if(""==c||isNaN(c))return!1;var d=a.indexOf(J);if(-1==d)return!1;var e=a.substring(d),f=m(e);return f>=c?!0:!1}function p(a,b){var c=b.maxPreDecimalPlaces;if(""==c||isNaN(c))return!1;var d=a.indexOf(J);if(d>=0)return!1;var e=m(a);return e>=c?!0:!1}function q(a,b){if(!b.max||b.max<0)return!1;var c=parseFloat(a);return c>b.max?!0:!1}function r(a,b){if(!b.min||b.min>0)return!1;var c=parseFloat(a);return c=0)return!1;var d=a.indexOf(I);if(0>d)return!0;var e=a.lastIndexOf(I),f=a.length-e-1;if(3>f)return!1;var g=m(a.substring(d));return g%3>0?!1:!0}function B(a){"string"==typeof a?this.map=C(a):this.map={}}function C(a){var b,c={},d=a.split(""),e=0;for(e=0;e=0?endPos=e.toString().length:endPos=startPos+d.toString().length,{start:startPos,end:endPos}):null},d=function(d){var e=b(d);if(void 0!==d.selectionStart)return document.activeElement&&document.activeElement!=d&&d.selectionStart==d.selectionEnd&&0==d.selectionStart?{start:d.value.length,end:d.value.length}:{start:d.selectionStart,end:d.selectionEnd};if(e.getSelection)return c(d,e);try{if("input"==d.nodeName.toLowerCase()){var f=b(d).document.selection.createRange(),g=d.createTextRange();g.setEndPoint("EndToStart",f);var h=g.text.length;return{start:h,end:h+f.text.length}}var i=c(d,e);if(!i)return i;var j=a.Range.current().clone(),k=j.clone().collapse().range,l=j.clone().collapse(!1).range;return k.moveStart("character",-1),l.moveStart("character",-1),0!=i.startPos&&""==k.text&&(i.startPos+=2),0!=i.endPos&&""==l.text&&(i.endPos+=2),i}catch(m){return{start:d.value.length,end:d.value.length}}},e=function(a,c,d){var e=b(a);if(a.setSelectionRange)void 0===d?(a.focus(),a.setSelectionRange(c,c)):(a.select(),a.selectionStart=c,a.selectionEnd=d);else if(a.createTextRange){var f=a.createTextRange();f.moveStart("character",c),d=d||c,f.moveEnd("character",d-a.value.length),f.select()}else if(e.getSelection){var h=e.document,i=e.getSelection(),j=h.createRange(),k=[c,void 0!==d?d:c];g([a],k),j.setStart(k[0].el,k[0].count),j.setEnd(k[1].el,k[1].count),i.removeAllRanges(),i.addRange(j)}else if(e.document.body.createTextRange){var j=document.body.createTextRange();j.moveToElementText(a),j.collapse(),j.moveStart("character",c),j.moveEnd("character",void 0!==d?d:c),j.select()}},f=function(a,b,c,d){"number"==typeof c[0]&&c[0]d.right||c.bottomd.bottom)}},a.redux.hideFields(),a.redux.checkRequired(),a.redux.initEvents(),a.redux.initQtip(),a.redux.tabCheck(),a.redux.notices(),a.redux.tabControl()}),a.redux.ajax_save=function(b){var c=a(document.getElementById("redux_ajax_overlay"));c.fadeIn(),jQuery(".redux-action_bar .spinner").addClass("is-active"),jQuery(".redux-action_bar input").attr("disabled","disabled");var d=jQuery(document.getElementById("redux_notification_bar"));d.slideUp(),jQuery(".redux-save-warn").slideUp(),jQuery(".redux_ajax_save_error").slideUp("medium",function(){jQuery(this).remove()});var e=jQuery(document.getElementById("redux-form-wrapper"));redux.fields.hasOwnProperty("editor")&&a.each(redux.fields.editor,function(a,b){var c=tinyMCE.get(a);c&&c.save()});var f=e.serialize();e.find("input[type=checkbox]").each(function(){if("undefined"!=typeof a(this).attr("name")){var b=a(this).is(":checked")?a(this).val():"0";f+="&"+a(this).attr("name")+"="+b}}),"redux_save"!=b.attr("name")&&(f+="&"+b.attr("name")+"="+b.val());var g=e.attr("data-nonce");return jQuery.ajax({type:"post",dataType:"json",url:ajaxurl,data:{action:redux.args.opt_name+"_ajax_save",nonce:g,opt_name:redux.args.opt_name,data:f},error:function(a){window.console||(console={}),console.log=console.log||function(a,b){},console.log(redux.ajax.console),console.log(a.responseText),jQuery(".redux-action_bar input").removeAttr("disabled"),c.fadeOut("fast"),jQuery(".redux-action_bar .spinner").removeClass("is-active"),alert(redux.ajax.alert)},success:function(b){if(b.action&&"reload"==b.action)location.reload(!0);else if("success"==b.status){jQuery(".redux-action_bar input").removeAttr("disabled"),c.fadeOut("fast"),jQuery(".redux-action_bar .spinner").removeClass("is-active"),redux.options=b.options,redux.errors=b.errors,redux.warnings=b.warnings,d.html(b.notification_bar).slideDown("fast"),(null!==b.errors||null!==b.warnings)&&a.redux.notices();var e=a(document.getElementById("redux_notification_bar")).find(".saved_notice");e.slideDown(),e.delay(4e3).slideUp()}else jQuery(".redux-action_bar input").removeAttr("disabled"),jQuery(".redux-action_bar .spinner").removeClass("is-active"),c.fadeOut("fast"),jQuery(".wrap h2:first").parent().append('"),jQuery(".redux_ajax_save_error").slideDown(),jQuery("html, body").animate({scrollTop:0},"slow")}}),!1},a.redux.initEvents=function(){a(".redux-presets-bar").on("click",function(){window.onbeforeunload=null}),a("#toplevel_page_"+redux.args.slug+" .wp-submenu a, #wp-admin-bar-"+redux.args.slug+" a.ab-item").click(function(b){if((a("#toplevel_page_"+redux.args.slug).hasClass("wp-menu-open")||a(this).hasClass("ab-item"))&&!a(this).parents("ul.ab-submenu:first").hasClass("ab-sub-secondary")&&a(this).attr("href").toLowerCase().indexOf(redux.args.slug+"&tab=")>=0){b.preventDefault();var c=a(this).attr("href").split("&tab=");return a("#"+c[1]+"_section_group_li_a").click(),a(this).parents("ul:first").find(".current").removeClass("current"),a(this).addClass("current"),a(this).parent().addClass("current"),!1}}),a(".redux-action_bar input").on("click",function(b){if(a(this).attr("name")==redux.args.opt_name+"[defaults]"){if(!confirm(redux.args.reset_confirm))return!1}else if(a(this).attr("name")==redux.args.opt_name+"[defaults-section]"&&!confirm(redux.args.reset_section_confirm))return!1;window.onbeforeunload=null,redux.args.ajax_save===!0&&(a.redux.ajax_save(a(this)),b.preventDefault())}),a(".expand_options").click(function(b){b.preventDefault();var c=a(".redux-container");if(a(c).hasClass("fully-expanded")){a(c).removeClass("fully-expanded");var d=a.cookie("redux_current_tab");a(".redux-container:first").find("#"+d+"_section_group").fadeIn(200,function(){0!==a(".redux-container:first").find("#redux-footer").length&&a.redux.stickyInfo(),a.redux.initFields()})}return a.redux.expandOptions(a(this).parents(".redux-container:first")),!1}),a(".saved_notice").is(":visible")&&a(".saved_notice").slideDown(),a(document.body).on("change",".redux-field input, .redux-field textarea, .redux-field select",function(){a(this).hasClass("noUpdate")||redux_change(a(this))});var b=a("#redux-footer").height();a("#redux-sticky-padder").css({height:b}),a("#redux-footer-sticky").removeClass("hide"),0!==a("#redux-footer").length&&(a(window).scroll(function(){a.redux.stickyInfo()}),a(window).resize(function(){a.redux.stickyInfo()})),a(".saved_notice").delay(4e3).slideUp()},a.redux.hideFields=function(){a("label[for='redux_hide_field']").each(function(b,c){var d=a(this).parent().parent();a(d).addClass("hidden")})},a.redux.checkRequired=function(){a.redux.required(),a("body").on("change",".redux-main select, .redux-main radio, .redux-main input[type=checkbox], .redux-main input[type=hidden]",function(b){a.redux.check_dependencies(this)}),a("body").on("check_dependencies",function(b,c){a.redux.check_dependencies(c)}),a("td > fieldset:empty,td > div:empty").parent().parent().hide()},a.redux.initQtip=function(){if(a().qtip){var b="",c=redux.args.hints.tip_style.shadow;c===!0&&(b="qtip-shadow");var d="",e=redux.args.hints.tip_style.color;""!==e&&(d="qtip-"+e);var f="",g=redux.args.hints.tip_style.rounded;g===!0&&(f="qtip-rounded");var h="",i=redux.args.hints.tip_style.style;""!==i&&(h="qtip-"+i);var j=b+","+d+","+f+","+h+",redux-qtip";j=j.replace(/,/g," ");var k=redux.args.hints.tip_position.my,l=redux.args.hints.tip_position.at;k=a.redux.verifyPos(k.toLowerCase(),!0),l=a.redux.verifyPos(l.toLowerCase(),!1);var m=redux.args.hints.tip_effect.show.event,n=redux.args.hints.tip_effect.hide.event,o=redux.args.hints.tip_effect.show.effect,p=redux.args.hints.tip_effect.show.duration,q=redux.args.hints.tip_effect.hide.effect,r=redux.args.hints.tip_effect.hide.duration;a("div.redux-dev-qtip").each(function(){a(this).qtip({content:{text:a(this).attr("qtip-content"),title:a(this).attr("qtip-title")},show:{effect:function(){a(this).slideDown(500)},event:"mouseover"},hide:{effect:function(){a(this).slideUp(500)},event:"mouseleave"},style:{classes:"qtip-shadow qtip-light"},position:{my:"top center",at:"bottom center"}})}),a("div.redux-hint-qtip").each(function(){a(this).qtip({content:{text:a(this).attr("qtip-content"),title:a(this).attr("qtip-title")},show:{effect:function(){switch(o){case"slide":a(this).slideDown(p);break;case"fade":a(this).fadeIn(p);break;default:a(this).show()}},event:m},hide:{effect:function(){switch(q){case"slide":a(this).slideUp(r);break;case"fade":a(this).fadeOut(r);break;default:a(this).hide(r)}},event:n},style:{classes:j},position:{my:k,at:l}})}),a("input[qtip-content]").each(function(){a(this).qtip({content:{text:a(this).attr("qtip-content"),title:a(this).attr("qtip-title")},show:"focus",hide:"blur",style:j,position:{my:k,at:l}})})}},a.redux.tabCheck=function(){a(".redux-group-tab-link-a").click(function(){var b=a(this);if(b.parent().hasClass("empty_section")&&b.parent().hasClass("hasSubSections")){var c=a(this).closest("ul").find(".redux-group-tab-link-a"),d=c.index(this);b=c.slice(d+1,d+2)}var e=b.parents(".redux-container:first"),f=b.data("rel"),g=e.find(".redux-group-tab-link-li.active:first .redux-group-tab-link-a").data("rel");if(g!==f){if(a("#currentSection").val(f),b.parents(".postbox-container:first").length||a.cookie("redux_current_tab",f,{expires:7,path:"/"}),e.find("#"+f+"_section_group_li").parents(".redux-group-tab-link-li").length){var h=e.find("#"+f+"_section_group_li").parents(".redux-group-tab-link-li").attr("id").split("_");h=h[0]}if(e.find("#toplevel_page_"+redux.args.slug+" .wp-submenu a.current").removeClass("current"),e.find("#toplevel_page_"+redux.args.slug+" .wp-submenu li.current").removeClass("current"),e.find("#toplevel_page_"+redux.args.slug+" .wp-submenu a").each(function(){var b=a(this).attr("href").split("&tab=");(b[1]==f||b[1]==h)&&(a(this).addClass("current"),a(this).parent().addClass("current"))}),e.find("#"+g+"_section_group_li").find("#"+g+"_section_group_li").length)e.find("#"+g+"_section_group_li").addClass("activeChild"),e.find("#"+f+"_section_group_li").addClass("active").removeClass("activeChild");else if(e.find("#"+f+"_section_group_li").parents("#"+g+"_section_group_li").length||e.find("#"+g+"_section_group_li").parents("ul.subsection").find("#"+f+"_section_group_li").length)e.find("#"+f+"_section_group_li").parents("#"+g+"_section_group_li").length?e.find("#"+g+"_section_group_li").addClass("activeChild").removeClass("active"):(e.find("#"+f+"_section_group_li").addClass("active"),e.find("#"+g+"_section_group_li").removeClass("active")),e.find("#"+f+"_section_group_li").removeClass("activeChild").addClass("active");else if(e.find("#"+f+"_section_group_li").addClass("active").removeClass("activeChild").find("ul.subsection").slideDown(),e.find("#"+g+"_section_group_li").find("ul.subsection").length){e.find("#"+g+"_section_group_li").find("ul.subsection").slideUp("fast",function(){e.find("#"+g+"_section_group_li").removeClass("active").removeClass("activeChild")});var i=e.find("#"+f+"_section_group_li").parents(".hasSubSections:first");i.length>0&&(e.find("#"+f+"_section_group_li").removeClass("active"),f=i.find(".redux-group-tab-link-a:first").data("rel"),i.hasClass("empty_section")?(i.find(".subsection li:first").addClass("active"),e.find("#"+f+"_section_group_li").removeClass("active").addClass("activeChild").find("ul.subsection").slideDown(),i=i.find(".subsection li:first"),f=i.find(".redux-group-tab-link-a:first").data("rel")):e.find("#"+f+"_section_group_li").addClass("active").removeClass("activeChild").find("ul.subsection").slideDown())}else e.find("#"+g+"_section_group_li").parents("ul.subsection").length?e.find("#"+g+"_section_group_li").parents("#"+f+"_section_group_li").length?e.find("#"+g+"_section_group_li").removeClass("active"):e.find("#"+g+"_section_group_li").parents("ul.subsection").slideUp("fast",function(){e.find("#"+g+"_section_group_li").removeClass("active"),e.find("#"+g+"_section_group_li").parents(".redux-group-tab-link-li").removeClass("active").removeClass("activeChild"),e.find("#"+f+"_section_group_li").parents(".redux-group-tab-link-li").addClass("activeChild").find("ul.subsection").slideDown(),e.find("#"+f+"_section_group_li").addClass("active")}):(e.find("#"+g+"_section_group_li").removeClass("active"),e.find("#"+f+"_section_group_li").parents(".redux-group-tab-link-li").length&&(e.find("#"+f+"_section_group_li").parents(".redux-group-tab-link-li").addClass("activeChild").find("ul.subsection").slideDown(),e.find("#"+f+"_section_group_li").addClass("active")));e.find("#"+g+"_section_group").hide(),e.find("#"+f+"_section_group").fadeIn(200,function(){0!==e.find("#redux-footer").length&&a.redux.stickyInfo(),a.redux.initFields()}),a("#toplevel_page_"+redux.args.slug).find(".current").removeClass("current")}});var b=decodeURI((new RegExp("tab=(.+?)(&|$)").exec(location.search)||[,""])[1]);""!==b?a.cookie("redux_current_tab_get")!==b&&(a.cookie("redux_current_tab",b,{expires:7,path:"/"}),a.cookie("redux_current_tab_get",b,{expires:7,path:"/"}),a("#"+b+"_section_group_li").click()):""!==a.cookie("redux_current_tab_get")&&a.removeCookie("redux_current_tab_get");var c=a("#"+a.cookie("redux_current_tab")+"_section_group_li_a");null===a.cookie("redux_current_tab")||"undefined"==typeof a.cookie("redux_current_tab")||0===c.length?a(".redux-container").find(".redux-group-tab-link-a:first").click():c.click()},a.redux.initFields=function(){a(".redux-group-tab:visible").find(".redux-field-init:visible").each(function(){var b=a(this).attr("data-type");if("undefined"!=typeof redux.field_objects&&redux.field_objects[b]&&redux.field_objects[b]&&redux.field_objects[b].init(),!redux.customizer&&a(this).hasClass("redux_remove_th")){var c=a(this).parents("tr:first"),d=c.find("th:first");d.html()&&d.html().length>0&&(a(this).prepend(d.html()),a(this).find(".redux_field_th").css("padding","0 0 10px 0")),a(this).parent().attr("colspan","2"),d.remove()}})},a.redux.notices=function(){redux.errors&&redux.errors.errors&&(a.each(redux.errors.errors,function(b,c){a.each(c.errors,function(b,c){a("#"+redux.args.opt_name+"-"+c.id).addClass("redux-field-error"),0===a("#"+redux.args.opt_name+"-"+c.id).parent().find(".redux-th-error").length?a("#"+redux.args.opt_name+"-"+c.id).append('
    '+c.msg+"
    "):a("#"+redux.args.opt_name+"-"+c.id).parent().find(".redux-th-error").html(c.msg).css("display","block")})}),a(".redux-container").each(function(){var b=a(this);b.find(".redux-menu-error").remove();var c=b.find(".redux-field-error").length;c>0&&(b.find(".redux-field-errors span").text(c),b.find(".redux-field-errors").slideDown(),b.find(".redux-group-tab").each(function(){var c=a(this).find(".redux-field-error").length;if(c>0){var d=a(this).attr("id").split("_");d=d[0],b.find('.redux-group-tab-link-a[data-key="'+d+'"]').prepend(''+c+""),b.find('.redux-group-tab-link-a[data-key="'+d+'"]').addClass("hasError");var e=b.find('.redux-group-tab-link-a[data-key="'+d+'"]').parents(".hasSubSections:first");e&&e.find(".redux-group-tab-link-a:first").addClass("hasError")}}))})),redux.warnings&&redux.warnings.warnings&&(a.each(redux.warnings.warnings,function(b,c){a.each(c.warnings,function(b,c){a("#"+redux.args.opt_name+"-"+c.id).addClass("redux-field-warning"),0===a("#"+redux.args.opt_name+"-"+c.id).parent().find(".redux-th-warning").length?a("#"+redux.args.opt_name+"-"+c.id).append('
    '+c.msg+"
    "):a("#"+redux.args.opt_name+"-"+c.id).parent().find(".redux-th-warning").html(c.msg).css("display","block")})}),a(".redux-container").each(function(){var b=a(this);b.find(".redux-menu-warning").remove();var c=b.find(".redux-field-warning").length;c>0&&(b.find(".redux-field-warnings span").text(c),b.find(".redux-field-warnings").slideDown(),b.find(".redux-group-tab").each(function(){var c=a(this).find(".redux-field-warning").length;if(c>0){var d=a(this).attr("id").split("_");d=d[0],b.find('.redux-group-tab-link-a[data-key="'+d+'"]').prepend(''+c+""),b.find('.redux-group-tab-link-a[data-key="'+d+'"]').addClass("hasWarning");var e=b.find('.redux-group-tab-link-a[data-key="'+d+'"]').parents(".hasSubSections:first");e&&e.find(".redux-group-tab-link-a:first").addClass("hasWarning")}}))}))},a.redux.tabControl=function(){a(".redux-section-tabs div").hide(),a(".redux-section-tabs div:first").show(),a(".redux-section-tabs ul li:first").addClass("active"),a(".redux-section-tabs ul li a").click(function(){a(".redux-section-tabs ul li").removeClass("active"),a(this).parent().addClass("active");var b=a(this).attr("href");return a(".redux-section-tabs div").hide(),a(b).fadeIn("medium",function(){a.redux.initFields()}),!1})},a.redux.required=function(){a.each(redux.folds,function(b,c){var d=a("#"+redux.args.opt_name+"-"+b);if(d.parents("tr:first").addClass("fold"),"hide"==c){if(d.parents("tr:first").addClass("hide"),d.hasClass("redux-container-section")){var e=a("#section-"+b);e.hasClass("redux-section-indent-start")&&(a("#section-table-"+b).hide().addClass("hide"),e.hide().addClass("hide"))}if(d.hasClass("redux-container-info")&&a("#info-"+b).hide().addClass("hide"), -d.hasClass("redux-container-divide")&&a("#divide-"+b).hide().addClass("hide"),d.hasClass("redux-container-raw")){var f=d.parents().find("table#"+redux.args.opt_name+"-"+b);f.hide().addClass("hide")}}})},a.redux.get_container_value=function(b){var c=a("#"+redux.args.opt_name+"-"+b).serializeForm();return null!==c&&"object"==typeof c&&c.hasOwnProperty(redux.args.opt_name)&&(c=c[redux.args.opt_name][b]),a("#"+redux.args.opt_name+"-"+b).hasClass("redux-container-media")&&(c=c.url),c},a.redux.check_dependencies=function(b){if(null!==redux.required){var c=a(b),d=c.parents(".redux-field:first").data("id");if(redux.required.hasOwnProperty(d)){var e=c.parents(".redux-field-container:first"),f=e.parents("tr:first").hasClass(".hide");a.each(redux.required[d],function(b,c){var d=a(this),e=!1,g=a("#"+redux.args.opt_name+"-"+b),h=g.parents("tr:first");if(f||(e=a.redux.check_parents_dependencies(b)),e===!0){if(g.hasClass("redux-container-section")){var i=a("#section-"+b);i.hasClass("redux-section-indent-start")&&i.hasClass("hide")&&(a("#section-table-"+b).fadeIn(300).removeClass("hide"),i.fadeIn(300).removeClass("hide"))}if(g.hasClass("redux-container-info")&&a("#info-"+b).fadeIn(300).removeClass("hide"),g.hasClass("redux-container-divide")&&a("#divide-"+b).fadeIn(300).removeClass("hide"),g.hasClass("redux-container-raw")){var j=g.parents().find("table#"+redux.args.opt_name+"-"+b);j.fadeIn(300).removeClass("hide")}h.fadeIn(300,function(){a(this).removeClass("hide"),redux.required.hasOwnProperty(b)&&a.redux.check_dependencies(a("#"+redux.args.opt_name+"-"+b).children().first()),a.redux.initFields()}),(g.hasClass("redux-container-section")||g.hasClass("redux-container-info"))&&h.css({display:"none"})}else e===!1&&h.fadeOut(100,function(){a(this).addClass("hide"),redux.required.hasOwnProperty(b)&&a.redux.required_recursive_hide(b)});d.find("select, radio, input[type=checkbox]").trigger("change")})}}},a.redux.required_recursive_hide=function(b){var c=a("#"+redux.args.opt_name+"-"+b).parents("tr:first");c.fadeOut(50,function(){if(a(this).addClass("hide"),a("#"+redux.args.opt_name+"-"+b).hasClass("redux-container-section")){var c=a("#section-"+b);c.hasClass("redux-section-indent-start")&&(a("#section-table-"+b).fadeOut(50).addClass("hide"),c.fadeOut(50).addClass("hide"))}if(a("#"+redux.args.opt_name+"-"+b).hasClass("redux-container-info")&&a("#info-"+b).fadeOut(50).addClass("hide"),a("#"+redux.args.opt_name+"-"+b).hasClass("redux-container-divide")&&a("#divide-"+b).fadeOut(50).addClass("hide"),a("#"+redux.args.opt_name+"-"+b).hasClass("redux-container-raw")){var d=a("#"+redux.args.opt_name+"-"+b).parents().find("table#"+redux.args.opt_name+"-"+b);d.fadeOut(50).addClass("hide")}redux.required.hasOwnProperty(b)&&a.each(redux.required[b],function(b){a.redux.required_recursive_hide(b)})})},a.redux.check_parents_dependencies=function(b){var c="";return redux.required_child.hasOwnProperty(b)?a.each(redux.required_child[b],function(b,d){if(a("#"+redux.args.opt_name+"-"+d.parent).parents("tr:first").hasClass(".hide"))c=!1;else if(c!==!1){var e=a.redux.get_container_value(d.parent);c=a.redux.check_dependencies_visibility(e,d)}}):c=!0,c},a.redux.check_dependencies_visibility=function(b,c){var d,e=!1,f=c.checkValue,g=c.operation;switch(g){case"=":case"equals":a.isArray(b)?a(b[0]).each(function(b,c){if(a.isArray(f))a(f).each(function(a,b){return c==b?(e=!0,!0):void 0});else if(c==f)return e=!0,!0}):a.isArray(f)?a(f).each(function(a,c){b==c&&(e=!0)}):b==f&&(e=!0);break;case"!=":case"not":a.isArray(b)?a(b).each(function(b,c){if(a.isArray(f))a(f).each(function(a,b){return c!=b?(e=!0,!0):void 0});else if(c!=f)return e=!0,!0}):a.isArray(f)?a(f).each(function(a,c){b!=c&&(e=!0)}):b!=f&&(e=!0);break;case">":case"greater":case"is_larger":parseFloat(b)>parseFloat(f)&&(e=!0);break;case">=":case"greater_equal":case"is_larger_equal":parseFloat(b)>=parseFloat(f)&&(e=!0);break;case"<":case"less":case"is_smaller":parseFloat(b)g)&&(g=h,b.attr("data-height",g),b.css("width","auto"),b.attr("data-width",b.width()),f=b.width()),f>d?(e=d/f,b.css("width",d),b.css("height",g*e),g*=e,f*=e):b.css("width","auto"),g>c?(e=c/g,b.css("height",c),b.css("width",f*e),f*=e,g*=e):b.css("height","auto");var i=(a(document.getElementById("redux-header")).height()-b.height())/2;i>0?b.css("margin-top",i):b.css("margin-top",0),a("#redux-header .redux_field_search")&&a("#redux-header .redux_field_search").css("right",a(b).width()+20)},a.redux.resizeAds=function(){var b,c=a("#redux-header");c.length?b=c.width()-c.find(".display_header").width()-30:(c=a("#customize-info"),b=c.width());var d=c.height(),e=c.find(".rAds");a(e).find("video").each(function(){a.redux.scaleToRatio(a(this),d,b)}),a(e).find("img").each(function(){a.redux.scaleToRatio(a(this),d,b)}),a(e).find("div").each(function(){a.redux.scaleToRatio(a(this),d,b)}),"-99999px"==e.css("left")&&e.css("display","none").css("left","auto"),e.fadeIn("slow")},a(document).ready(function(){redux.rAds&&setTimeout(function(){var b;a("#redux-header").length>0?(a("#redux-header").append('
    '),b=a("#redux-header")):(a("#customize-theme-controls ul").first().prepend('
  • '),b=a("#redux_rAds")),b.css("position","relative"),b.find(".rAds").attr("style","position:absolute; top: 6px; right: 6px; display:block !important;overflow:hidden;").css("left","-99999px"),b.find(".rAds").html(redux.rAds.replace(//,""));var c=b.find(".rAds");b.height(),b.width()-b.find(".display_header").width()-30;c.find("a").css("float","right").css("line-height",b.height()+"px").css("margin-left","5px"),a(document).ajaxComplete(function(){c.find("a").hide(),setTimeout(function(){a.redux.resizeAds(),c.find("a").fadeIn()},1400),setTimeout(function(){a.redux.resizeAds()},1500),a(document).unbind("ajaxComplete")}),a(window).resize(function(){a.redux.resizeAds()})},400)})}(jQuery),jQuery.noConflict();var confirmOnPageExit=function(a){a=a||window.event;var b=redux.args.save_pending;return a&&(a.returnValue=b),window.onbeforeunload=null,b}; \ No newline at end of file diff --git a/library/admin/ReduxCore/assets/js/vendor.min.js b/library/admin/ReduxCore/assets/js/vendor.min.js deleted file mode 100644 index fc3d8efb..00000000 --- a/library/admin/ReduxCore/assets/js/vendor.min.js +++ /dev/null @@ -1 +0,0 @@ -!function(a){"function"==typeof define&&define.amd?jQueryCookie.define(["jquery"],a):a(jQuery)}(function(a){function b(a){return a}function c(a){return decodeURIComponent(a.replace(e," "))}function d(a){0===a.indexOf('"')&&(a=a.slice(1,-1).replace(/\\"/g,'"').replace(/\\\\/g,"\\"));try{return f.json?JSON.parse(a):a}catch(b){}}var e=/\+/g,f=a.cookie=function(e,g,h){if(void 0!==g){if(h=a.extend({},f.defaults,h),"number"==typeof h.expires){var i=h.expires,j=h.expires=new Date;j.setDate(j.getDate()+i)}return g=f.json?JSON.stringify(g):String(g),document.cookie=[f.raw?e:encodeURIComponent(e),"=",f.raw?g:encodeURIComponent(g),h.expires?"; expires="+h.expires.toUTCString():"",h.path?"; path="+h.path:"",h.domain?"; domain="+h.domain:"",h.secure?"; secure":""].join("")}for(var k=f.raw?b:c,l=document.cookie.split("; "),m=e?void 0:{},n=0,o=l.length;o>n;n++){var p=l[n].split("="),q=k(p.shift()),r=k(p.join("="));if(e&&e===q){m=d(r);break}e||(m[q]=d(r))}return m};f.defaults={},a.removeCookie=function(b,c){return void 0!==a.cookie(b)?(a.cookie(b,"",a.extend({},c,{expires:-1})),!0):!1}}),function(a){a.fn.serializeForm=function(){if(this.length<1)return!1;var b={},c=b,d=':input[type!="checkbox"][type!="radio"], input:checked',e=function(){if(!this.disabled){var d=this.name.replace(/\[([^\]]+)?\]/g,",$1").split(","),e=d.length-1,f=a(this);if(d[0]){for(var g=0;e>g;g++)c=c[d[g]]=c[d[g]]||(""===d[g+1]||"0"===d[g+1]?[]:{});void 0!==c.length?c.push(f.val()):c[d[e]]=f.val(),c=b}}};return this.filter(d).each(e),this.find(d).each(e),b}}(jQuery),function(a){a.fn.typeWatch=function(b){function c(b,c){var d=a(b.el).val();(d.length>=f.captureLength&&d.toUpperCase()!=b.text||c&&d.length>=f.captureLength)&&(b.text=d.toUpperCase(),b.cb.call(b.el,d))}function d(b){var d=b.type.toUpperCase();if(a.inArray(d,f.inputTypes)>=0){var e={timer:null,text:a(b).val().toUpperCase(),cb:f.callback,el:b,wait:f.wait};f.highlight&&a(b).focus(function(){this.select()});var g=function(b){var d=e.wait,g=!1,h=this.type.toUpperCase();"undefined"!=typeof b.keyCode&&13==b.keyCode&&"TEXTAREA"!=h&&a.inArray(h,f.inputTypes)>=0&&(d=1,g=!0);var i=function(){c(e,g)};clearTimeout(e.timer),e.timer=setTimeout(i,d)};a(b).on("keydown paste cut input",g)}}var e=["TEXT","TEXTAREA","PASSWORD","TEL","SEARCH","URL","EMAIL","DATETIME","DATE","MONTH","WEEK","TIME","DATETIME-LOCAL","NUMBER","RANGE"],f=a.extend({wait:750,callback:function(){},highlight:!0,captureLength:2,inputTypes:e},b);return this.each(function(){d(this)})}}(jQuery),function(a){function b(){var a="!@#$%^&*()+=[]\\';,/{}|\":<>?~`.-_";return a+=" "}function c(){var a="¬€£¦";return a}function d(b,c,d){b.each(function(){var b=a(this);b.bind("keyup change paste",function(a){var e="";a.originalEvent&&a.originalEvent.clipboardData&&a.originalEvent.clipboardData.getData&&(e=a.originalEvent.clipboardData.getData("text/plain")),setTimeout(function(){h(b,c,d,e)},0)}),b.bind("keypress",function(a){var e=a.charCode?a.charCode:a.which;if(!(g(e)||a.ctrlKey||a.metaKey)){var f=String.fromCharCode(e),h=b.selection(),i=h.start,j=h.end,k=b.val(),l=k.substring(0,i)+f+k.substring(j),m=c(l,d);m!=l&&a.preventDefault()}})})}function e(b,c){var d=parseFloat(a(b).val()),e=a(b);return isNaN(d)?void e.val(""):(f(c.min)&&dc.max&&e.val("")))}function f(a){return!isNaN(a)}function g(a){return a>=32?!1:10==a?!1:13==a?!1:!0}function h(a,b,c,d){var e=a.val();""==e&&d.length>0&&(e=d);var f=b(e,c);if(e!=f){var g=a.alphanum_caret();a.val(f),e.length==f.length+1?a.alphanum_caret(g-1):a.alphanum_caret(g)}}function i(b,c){"undefined"==typeof c&&(c=D);var d,e={};return d="string"==typeof b?F[b]:"undefined"==typeof b?{}:b,a.extend(e,c,d),"undefined"==typeof e.blacklist&&(e.blacklistSet=x(e.allow,e.disallow)),e}function j(b){var c,d={};return c="string"==typeof b?G[b]:"undefined"==typeof b?{}:b,a.extend(d,E,c),d}function k(a,b,c){return c.maxLength&&a.length>=c.maxLength?!1:c.allow.indexOf(b)>=0?!0:c.allowSpace&&" "==b?!0:c.blacklistSet.contains(b)?!1:!c.allowNumeric&&K[b]?!1:!c.allowUpper&&u(b)?!1:!c.allowLower&&v(b)?!1:!c.allowCaseless&&w(b)?!1:!c.allowLatin&&L.contains(b)?!1:c.allowOtherCharSets?!0:K[b]||L.contains(b)?!0:!1}function l(a,b,c){if(K[b])return n(a,c)?!1:p(a,c)?!1:o(a,c)?!1:q(a+b,c)?!1:r(a+b,c)?!1:!0;if(c.allowPlus&&"+"==b&&""==a)return!0;if(c.allowMinus&&"-"==b&&""==a)return!0;if(b==I&&c.allowThouSep&&A(a,b))return!0;if(b==J){if(a.indexOf(J)>=0)return!1;if(c.allowDecSep)return!0}return!1}function m(a){return a+="",a.replace(/[^0-9]/g,"").length}function n(a,b){var c=b.maxDigits;if(""==c||isNaN(c))return!1;var d=m(a);return d>=c?!0:!1}function o(a,b){var c=b.maxDecimalPlaces;if(""==c||isNaN(c))return!1;var d=a.indexOf(J);if(-1==d)return!1;var e=a.substring(d),f=m(e);return f>=c?!0:!1}function p(a,b){var c=b.maxPreDecimalPlaces;if(""==c||isNaN(c))return!1;var d=a.indexOf(J);if(d>=0)return!1;var e=m(a);return e>=c?!0:!1}function q(a,b){if(!b.max||b.max<0)return!1;var c=parseFloat(a);return c>b.max?!0:!1}function r(a,b){if(!b.min||b.min>0)return!1;var c=parseFloat(a);return c=0)return!1;var d=a.indexOf(I);if(0>d)return!0;var e=a.lastIndexOf(I),f=a.length-e-1;if(3>f)return!1;var g=m(a.substring(d));return g%3>0?!1:!0}function B(a){"string"==typeof a?this.map=C(a):this.map={}}function C(a){var b,c={},d=a.split(""),e=0;for(e=0;e=0?endPos=e.toString().length:endPos=startPos+d.toString().length,{start:startPos,end:endPos}):null},d=function(d){var e=b(d);if(void 0!==d.selectionStart)return document.activeElement&&document.activeElement!=d&&d.selectionStart==d.selectionEnd&&0==d.selectionStart?{start:d.value.length,end:d.value.length}:{start:d.selectionStart,end:d.selectionEnd};if(e.getSelection)return c(d,e);try{if("input"==d.nodeName.toLowerCase()){var f=b(d).document.selection.createRange(),g=d.createTextRange();g.setEndPoint("EndToStart",f);var h=g.text.length;return{start:h,end:h+f.text.length}}var i=c(d,e);if(!i)return i;var j=a.Range.current().clone(),k=j.clone().collapse().range,l=j.clone().collapse(!1).range;return k.moveStart("character",-1),l.moveStart("character",-1),0!=i.startPos&&""==k.text&&(i.startPos+=2),0!=i.endPos&&""==l.text&&(i.endPos+=2),i}catch(m){return{start:d.value.length,end:d.value.length}}},e=function(a,c,d){var e=b(a);if(a.setSelectionRange)void 0===d?(a.focus(),a.setSelectionRange(c,c)):(a.select(),a.selectionStart=c,a.selectionEnd=d);else if(a.createTextRange){var f=a.createTextRange();f.moveStart("character",c),d=d||c,f.moveEnd("character",d-a.value.length),f.select()}else if(e.getSelection){var h=e.document,i=e.getSelection(),j=h.createRange(),k=[c,void 0!==d?d:c];g([a],k),j.setStart(k[0].el,k[0].count),j.setEnd(k[1].el,k[1].count),i.removeAllRanges(),i.addRange(j)}else if(e.document.body.createTextRange){var j=document.body.createTextRange();j.moveToElementText(a),j.collapse(),j.moveStart("character",c),j.moveEnd("character",void 0!==d?d:c),j.select()}},f=function(a,b,c,d){"number"==typeof c[0]&&c[0]?~`.-_'; - blacklist += " "; // 'Space' is on the blacklist but can be enabled using the 'allowSpace' config entry - return blacklist; - } - - // Return the blacklisted special chars that are NOT encodable using 7-bit ascii - // We want this .js file to be encoded using 7-bit ascii so it can reach the widest possible audience - // Higher order chars must be escaped eg "\xAC" - // Not too worried about comments containing higher order characters for now (let's wait and see if it becomes a problem) - function getBlacklistNonAscii(){ - var blacklist = - "\xAC" // ¬ - + "\u20AC" // € - + "\xA3" // £ - + "\xA6" // ¦ - ; - return blacklist; - } - - // End Settings //////////////////////////////////////////////////////// - - - // Implementation details go here //////////////////////////////////////////////////////// - - function setupEventHandlers($textboxes, trimFunction, settings) { - - $textboxes.each(function(){ - - var $textbox = $(this); - - $textbox.bind("keyup change paste", function(e){ - - var pastedText = ""; - - if(e.originalEvent && e.originalEvent.clipboardData && e.originalEvent.clipboardData.getData) - pastedText = e.originalEvent.clipboardData.getData("text/plain") - - // setTimeout is necessary for handling the 'paste' event - setTimeout(function(){ - trimTextbox($textbox, trimFunction, settings, pastedText); - }, 0); - }); - - $textbox.bind("keypress", function(e){ - - // Determine which key is pressed. - // If it's a control key, then allow the event's default action to occur eg backspace, tab - var charCode = !e.charCode ? e.which : e.charCode; - if(isControlKey(charCode) - || e.ctrlKey - || e.metaKey ) // cmd on MacOS - return; - - var newChar = String.fromCharCode(charCode); - - // Determine if some text was selected / highlighted when the key was pressed - var selectionObject = $textbox.selection(); - var start = selectionObject.start; - var end = selectionObject.end; - - var textBeforeKeypress = $textbox.val(); - - // The new char may be inserted: - // 1) At the start - // 2) In the middle - // 3) At the end - // 4) User highlights some text and then presses a key which would replace the highlighted text - // - // Here we build the string that would result after the keypress. - // If the resulting string is invalid, we cancel the event. - // Unfortunately, it isn't enough to just check if the new char is valid because some chars - // are position sensitive eg the decimal point '.'' or the minus sign '-'' are only valid in certain positions. - var potentialTextAfterKeypress = textBeforeKeypress.substring(0, start) + newChar + textBeforeKeypress.substring(end); - var validatedText = trimFunction(potentialTextAfterKeypress, settings); - - // If the keypress would cause the textbox to contain invalid characters, then cancel the keypress event - if(validatedText != potentialTextAfterKeypress) - e.preventDefault(); - }); - }); - - } - - // Ensure the text is a valid number when focus leaves the textbox - // This catches the case where a user enters '-' or '.' without entering any digits - function numericField_Blur(inputBox, settings) { - var fieldValueNumeric = parseFloat($(inputBox).val()); - var $inputBox = $(inputBox); - - if(isNaN(fieldValueNumeric)) { - $inputBox.val(""); - return; - } - - if(isNumeric(settings.min) && fieldValueNumeric < settings.min) - $inputBox.val(""); - - if(isNumeric(settings.max) && fieldValueNumeric > settings.max) - $inputBox.val(""); - } - - function isNumeric(value) { - return !isNaN(value); - } - - function isControlKey(charCode) { - - if(charCode >= 32) - return false; - if(charCode == 10) - return false; - if(charCode == 13) - return false; - - return true; - } - - // One way to prevent a character being entered is to cancel the keypress event. - // However, this gets messy when you have to deal with things like copy paste which isn't a keypress. - // Which event gets fired first, keypress or keyup? What about IE6 etc etc? - // Instead, it's easier to allow the 'bad' character to be entered and then to delete it immediately after. - - function trimTextbox($textBox, trimFunction, settings, pastedText){ - - var inputString = $textBox.val(); - - if(inputString == "" && pastedText.length > 0) - inputString = pastedText; - - var outputString = trimFunction(inputString, settings); - - if(inputString == outputString) - return; - - var caretPos = $textBox.alphanum_caret(); - - $textBox.val(outputString); - - //Reset the caret position - if(inputString.length ==(outputString.length + 1)) - $textBox.alphanum_caret(caretPos - 1); - else - $textBox.alphanum_caret(caretPos); - } - - function getCombinedSettingsAlphaNum(settings, defaultSettings){ - if(typeof defaultSettings == "undefined") - defaultSettings = DEFAULT_SETTINGS_ALPHANUM; - var userSettings, combinedSettings = {}; - if(typeof settings === "string") - userSettings = CONVENIENCE_SETTINGS_ALPHANUM[settings]; - else if(typeof settings == "undefined") - userSettings = {}; - else - userSettings = settings; - - $.extend(combinedSettings, defaultSettings, userSettings); - - if(typeof combinedSettings.blacklist == 'undefined') - combinedSettings.blacklistSet = getBlacklistSet(combinedSettings.allow, combinedSettings.disallow); - - return combinedSettings; - } - - function getCombinedSettingsNum(settings){ - var userSettings, combinedSettings = {}; - if(typeof settings === "string") - userSettings = CONVENIENCE_SETTINGS_NUMERIC[settings]; - else if(typeof settings == "undefined") - userSettings = {}; - else - userSettings = settings; - - $.extend(combinedSettings, DEFAULT_SETTINGS_NUM, userSettings); - - return combinedSettings; - } - - - // This is the heart of the algorithm - function alphanum_allowChar(validatedStringFragment, Char, settings){ - - if(settings.maxLength && validatedStringFragment.length >= settings.maxLength) - return false; - - if(settings.allow.indexOf(Char) >=0 ) - return true; - - if(settings.allowSpace && (Char == " ")) - return true; - - if(settings.blacklistSet.contains(Char)) - return false; - - if(!settings.allowNumeric && DIGITS[Char]) - return false; - - if(!settings.allowUpper && isUpper(Char)) - return false; - - if(!settings.allowLower && isLower(Char)) - return false; - - if(!settings.allowCaseless && isCaseless(Char)) - return false; - - if(!settings.allowLatin && LATIN_CHARS.contains(Char)) - return false; - - if(!settings.allowOtherCharSets){ - if(DIGITS[Char] || LATIN_CHARS.contains(Char)) - return true; - else - return false; - } - - return true; - } - - function numeric_allowChar(validatedStringFragment, Char, settings){ - - if(DIGITS[Char]) { - - if(isMaxDigitsReached(validatedStringFragment, settings)) - return false; - - if(isMaxPreDecimalsReached(validatedStringFragment, settings)) - return false; - - if(isMaxDecimalsReached(validatedStringFragment, settings)) - return false; - - if(isGreaterThanMax(validatedStringFragment + Char, settings)) - return false; - - if(isLessThanMin(validatedStringFragment + Char, settings)) - return false; - - return true; - } - - if(settings.allowPlus && Char == '+' && validatedStringFragment == '') - return true; - - if(settings.allowMinus && Char == '-' && validatedStringFragment == '') - return true; - - if(Char == THOU_SEP && settings.allowThouSep && allowThouSep(validatedStringFragment, Char)) - return true; - - if(Char == DEC_SEP) { - // Only one decimal separator allowed - if(validatedStringFragment.indexOf(DEC_SEP) >= 0) - return false; - if(settings.allowDecSep) - return true; - } - - return false; - } - - function countDigits(string) { - - // Error handling, nulls etc - string = string + ""; - - // Count the digits - return string.replace(/[^0-9]/g,"").length; - } - - function isMaxDigitsReached(string, settings) { - - var maxDigits = settings.maxDigits; - - if(maxDigits == "" || isNaN(maxDigits)) - return false; // In this case, there is no maximum - - var numDigits = countDigits(string); - - if(numDigits >= maxDigits) - return true; - - return false; - } - - function isMaxDecimalsReached(string, settings) { - - var maxDecimalPlaces = settings.maxDecimalPlaces; - - if(maxDecimalPlaces == "" || isNaN(maxDecimalPlaces)) - return false; // In this case, there is no maximum - - var indexOfDecimalPoint = string.indexOf(DEC_SEP); - - if(indexOfDecimalPoint == -1) - return false; - - var decimalSubstring = string.substring(indexOfDecimalPoint); - var numDecimals = countDigits(decimalSubstring); - - if(numDecimals >= maxDecimalPlaces) - return true; - - return false; - } - - function isMaxPreDecimalsReached(string, settings) { - - var maxPreDecimalPlaces = settings.maxPreDecimalPlaces; - - if(maxPreDecimalPlaces == "" || isNaN(maxPreDecimalPlaces)) - return false; // In this case, there is no maximum - - var indexOfDecimalPoint = string.indexOf(DEC_SEP); - - if(indexOfDecimalPoint >= 0) - return false; - - var numPreDecimalDigits = countDigits(string); - - if(numPreDecimalDigits >= maxPreDecimalPlaces) - return true; - - return false; - } - - function isGreaterThanMax(numericString, settings) { - - if(!settings.max || settings.max < 0) - return false; - - var outputNumber = parseFloat(numericString); - if(outputNumber > settings.max) - return true; - - return false; - } - - function isLessThanMin(numericString, settings) { - - if(!settings.min || settings.min > 0) - return false; - - var outputNumber = parseFloat(numericString); - if(outputNumber < settings.min) - return true; - - return false; - } - - /******************************** - * Trims a string according to the settings provided - ********************************/ - function trimAlphaNum(inputString, settings){ - - if(typeof inputString != "string") - return inputString; - - var inChars = inputString.split(""); - var outChars = []; - var i = 0; - var Char; - - for(i=0; i= 0) - return false; - - var posOfFirstThouSep = currentString.indexOf(THOU_SEP); - - // Check if this is the first occurrence of a THOU_SEP - if(posOfFirstThouSep < 0) - return true; - - var posOfLastThouSep = currentString.lastIndexOf(THOU_SEP); - var charsSinceLastThouSep = currentString.length - posOfLastThouSep - 1; - - // Check if there has been 3 digits since the last THOU_SEP - if(charsSinceLastThouSep < 3) - return false; - - var digitsSinceFirstThouSep = countDigits(currentString.substring(posOfFirstThouSep)); - - // Check if there has been a multiple of 3 digits since the first THOU_SEP - if((digitsSinceFirstThouSep % 3) > 0) - return false; - - return true; - } - - //////////////////////////////////////////////////////////////////////////////////// - // Implementation of a Set - //////////////////////////////////////////////////////////////////////////////////// - function Set(elems){ - if(typeof elems == "string") - this.map = stringToMap(elems); - else - this.map = {}; - } - - Set.prototype.add = function(set){ - - var newSet = this.clone(); - - for(var key in set.map) - newSet.map[key] = true; - - return newSet; - } - - Set.prototype.subtract = function(set){ - - var newSet = this.clone(); - - for(var key in set.map) - delete newSet.map[key]; - - return newSet; - } - - Set.prototype.contains = function(key){ - if(this.map[key]) - return true; - else - return false; - } - - Set.prototype.clone = function(){ - var newSet = new Set(); - - for(var key in this.map) - newSet.map[key] = true; - - return newSet; - } - //////////////////////////////////////////////////////////////////////////////////// - - function stringToMap(string){ - var map = {}; - var array = string.split(""); - var i=0; - var Char; - - for(i=0; i=0){endPos=i.toString().length}else{endPos=startPos+r.toString().length}return{start:startPos,end:endPos}},s=function(t){var n=r(t);if(t.selectionStart!==undefined){if(document.activeElement&&document.activeElement!=t&&t.selectionStart==t.selectionEnd&&t.selectionStart==0){return{start:t.value.length,end:t.value.length}}return{start:t.selectionStart,end:t.selectionEnd}}else if(n.getSelection){return i(t,n)}else{try{if(t.nodeName.toLowerCase()=="input"){var s=r(t).document.selection.createRange(),o=t.createTextRange();o.setEndPoint("EndToStart",s);var u=o.text.length;return{start:u,end:u+s.text.length}}else{var a=i(t,n);if(!a){return a}var f=e.Range.current().clone(),l=f.clone().collapse().range,c=f.clone().collapse(false).range;l.moveStart("character",-1);c.moveStart("character",-1);if(a.startPos!=0&&l.text==""){a.startPos+=2}if(a.endPos!=0&&c.text==""){a.endPos+=2}return a}}catch(h){return{start:t.value.length,end:t.value.length}}}},o=function(e,t,n){var i=r(e);if(e.setSelectionRange){if(n===undefined){e.focus();e.setSelectionRange(t,t)}else{e.select();e.selectionStart=t;e.selectionEnd=n}}else if(e.createTextRange){var s=e.createTextRange();s.moveStart("character",t);n=n||t;s.moveEnd("character",n-e.value.length);s.select()}else if(i.getSelection){var o=i.document,u=i.getSelection(),f=o.createRange(),l=[t,n!==undefined?n:t];a([e],l);f.setStart(l[0].el,l[0].count);f.setEnd(l[1].el,l[1].count);u.removeAllRanges();u.addRange(f)}else if(i.document.body.createTextRange){var f=document.body.createTextRange();f.moveToElementText(e);f.collapse();f.moveStart("character",t);f.moveEnd("character",n!==undefined?n:t);f.select()}},u=function(e,t,n,r){if(typeof n[0]==="number"&&n[0]= options.captureLength AND text != saved text OR if override AND text >= options.captureLength - if ((value.length >= options.captureLength && value.toUpperCase() != timer.text) - || (override && value.length >= options.captureLength)) - { - timer.text = value.toUpperCase(); - timer.cb.call(timer.el, value); - } - }; - - function watchElement(elem) { - var elementType = elem.type.toUpperCase(); - if (jQuery.inArray(elementType, options.inputTypes) >= 0) { - - // Allocate timer element - var timer = { - timer: null, - text: jQuery(elem).val().toUpperCase(), - cb: options.callback, - el: elem, - wait: options.wait - }; - - // Set focus action (highlight) - if (options.highlight) { - jQuery(elem).focus( - function() { - this.select(); - }); - } - - // Key watcher / clear and reset the timer - var startWatch = function(evt) { - var timerWait = timer.wait; - var overrideBool = false; - var evtElementType = this.type.toUpperCase(); - - // If enter key is pressed and not a TEXTAREA and matched inputTypes - if (typeof evt.keyCode != 'undefined' && evt.keyCode == 13 && evtElementType != 'TEXTAREA' && jQuery.inArray(evtElementType, options.inputTypes) >= 0) { - timerWait = 1; - overrideBool = true; - } - - var timerCallbackFx = function() { - checkElement(timer, overrideBool) - } - - // Clear timer - clearTimeout(timer.timer); - timer.timer = setTimeout(timerCallbackFx, timerWait); - }; - - jQuery(elem).on('keydown paste cut input', startWatch); - } - }; - - // Watch Each Element - return this.each(function() { - watchElement(this); - }); - - }; -})(jQuery); \ No newline at end of file diff --git a/library/admin/ReduxCore/assets/js/vendor/jsonview.js b/library/admin/ReduxCore/assets/js/vendor/jsonview.js deleted file mode 100644 index 1afe0271..00000000 --- a/library/admin/ReduxCore/assets/js/vendor/jsonview.js +++ /dev/null @@ -1,265 +0,0 @@ - -/* global console, jsonView */ -/* - * ViewJSON - * Version 1.0 - * A Google Chrome extension to display JSON in a user-friendly format - * - * This is a chromeified version of the JSONView Firefox extension by Ben Hollis: - * http://jsonview.com - * http://code.google.com/p/jsonview - * - * Also based on the XMLTree Chrome extension by Moonty & alan.stroop - * https://chrome.google.com/extensions/detail/gbammbheopgpmaagmckhpjbfgdfkpadb - * - * port by Jamie Wilkinson (@jamiew) | http://jamiedubs.com | http://github.com/jamiew - * MIT license / copyfree (f) F.A.T. Lab http://fffff.at - * Speed Project Approved: 2h - */ - -function collapse(evt) { - var collapser = evt.target; - var target = collapser.parentNode.getElementsByClassName('collapsible'); - if (!target.length) { - return; - } - target = target[0]; - if (target.style.display === 'none') { - var ellipsis = target.parentNode.getElementsByClassName('ellipsis')[0]; - target.parentNode.removeChild(ellipsis); - target.style.display = ''; - } else { - target.style.display = 'none'; - var ellipsis = document.createElement('span'); - ellipsis.className = 'ellipsis'; - ellipsis.innerHTML = ' … '; - target.parentNode.insertBefore(ellipsis, target); - } - collapser.innerHTML = (collapser.innerHTML === '-') ? '+' : '-'; -} - -function addCollapser(item) { - // This mainly filters out the root object (which shouldn't be collapsible) - if (item.nodeName !== 'LI') { - return; - } - var collapser = document.createElement('div'); - collapser.className = 'collapser'; - collapser.innerHTML = '-'; - collapser.addEventListener('click', collapse, false); - item.insertBefore(collapser, item.firstChild); -} - -function jsonView(id, target) { - this.debug = false; - if (id.indexOf("#") !== -1) { - this.idType = "id"; - this.id = id.replace('#', ''); - } else if (id.indexOf(".") !== -1) { - this.idType = "class"; - this.id = id.replace('.', ''); - } else { - if (this.debug) { console.log("Can't find that element"); } - return; - } - - this.data = document.getElementById(this.id).innerHTML; - if (typeof(target) !== undefined) { - if (target.indexOf("#") !== -1) { - this.targetType = "id"; - this.target = target.replace('#', ''); - } else if (id.indexOf(".") !== -1) { - this.targetType = "class"; - this.target = target.replace('.', ''); - } else { - if (this.debug) { console.log("Can't find the target element"); } - return; - } - } - // Note: now using "*.json*" URI matching rather than these page regexes -- save CPU cycles! - // var is_json = /^\s*(\{.*\})\s*$/.test(this.data); - // var is_jsonp = /^.*\(\s*(\{.*\})\s*\)$/.test(this.data); - // if(is_json || is_jsonp){ - // Our manifest specifies that we only do URLs matching '.json', so attempt to sanitize any HTML - // added by Chrome's "text/plain" or "text/html" handlers - if (/^\(.*)\<\/pre\>$/.test(this.data)) { - if (this.debug) { console.log("JSONView: data is wrapped in
    ...
    , stripping HTML..."); } - this.data = this.data.replace(/<(?:.|\s)*?>/g, ''); //Aggressively strip HTML. - } - // Test if what remains is JSON or JSONp - var json_regex = /^\s*([\[\{].*[\}\]])\s*$/; // Ghetto, but it works - var jsonp_regex = /^[\s\u200B\uFEFF]*([\w$\[\]\.]+)[\s\u200B\uFEFF]*\([\s\u200B\uFEFF]*([\[{][\s\S]*[\]}])[\s\u200B\uFEFF]*\);?[\s\u200B\uFEFF]*$/; - var jsonp_regex2 = /([\[\{][\s\S]*[\]\}])\)/; // more liberal support... this allows us to pass the jsonp.json & jsonp2.json tests - var is_json = json_regex.test(this.data); - var is_jsonp = jsonp_regex.test(this.data); - if (this.debug) { console.log("JSONView: is_json=" + is_json + " is_jsonp=" + is_jsonp); } - if (is_json || is_jsonp) { - if (this.debug) { console.log("JSONView: sexytime!"); } - // JSONFormatter json->HTML prototype straight from Firefox JSONView - // For reference: http://code.google.com/p/jsonview - - function JSONFormatter() { - // No magic required. - } - JSONFormatter.prototype = { - htmlEncode: function(t) { - return t != null ? t.toString().replace(/&/g, "&").replace(/"/g, """).replace(//g, ">") : ''; - }, - decorateWithSpan: function(value, className) { - return '' + this.htmlEncode(value) + ''; - }, - // Convert a basic JSON datatype (number, string, boolean, null, object, array) into an HTML fragment. - valueToHTML: function(value) { - var valueType = typeof value; - var output = ""; - if (value === null) { - output += this.decorateWithSpan('null', 'null'); - } else if (value && value.constructor === Array) { - output += this.arrayToHTML(value); - } else if (valueType === 'object') { - output += this.objectToHTML(value); - } else if (valueType === 'number') { - output += this.decorateWithSpan(value, 'num'); - } else if (valueType === 'string') { - if (/^(http|https):\/\/[^\s]+$/.test(value)) { - output += '' + this.htmlEncode(value) + ''; - } else { - output += this.decorateWithSpan('"' + value + '"', 'string'); - } - } else if (valueType === 'boolean') { - output += this.decorateWithSpan(value, 'bool'); - } - return output; - }, - // Convert an array into an HTML fragment - arrayToHTML: function(json) { - var output = '[
      '; - var hasContents = false; - for (var prop in json) { - hasContents = true; - output += '
    • '; - output += this.valueToHTML(json[prop]); - output += '
    • '; - } - output += '
    ]'; - if (!hasContents) { - output = "[ ]"; - } - return output; - }, - // Convert a JSON object to an HTML fragment - objectToHTML: function(json) { - var output = '{
      '; - var hasContents = false; - for (var prop in json) { - hasContents = true; - output += '
    • '; - output += '' + this.htmlEncode(prop) + ': '; - output += this.valueToHTML(json[prop]); - output += '
    • '; - } - output += '
    }'; - if (!hasContents) { - output = "{ }"; - } - return output; - }, - // Convert a whole JSON object into a formatted HTML document. - jsonToHTML: function(json, callback, uri) { - var output = ''; - if (callback) { - output += '
    ' + callback + ' (
    '; - output += '
    '; - } else { - output += '
    '; - } - output += this.valueToHTML(json); - output += '
    '; - if (callback) { - output += '
    )
    '; - } - return this.toHTML(output, uri); - }, - // Produce an error document for when parsing fails. - errorPage: function(error, data, uri) { - // var output = '
    ' + this.stringbundle.GetStringFromName('errorParsing') + '
    '; - // output += '

    ' + this.stringbundle.GetStringFromName('docContents') + ':

    '; - var output = '
    Error parsing JSON: ' + error.message + '
    '; - output += '

    ' + error.stack + ':

    '; - output += '
    ' + this.htmlEncode(data) + '
    '; - return this.toHTML(output, uri + ' - Error'); - }, - // Wrap the HTML fragment in a full document. Used by jsonToHTML and errorPage. - toHTML: function(content) { - return content; - } - }; - // Sanitize & output -- all magic from JSONView Firefox - this.jsonFormatter = new JSONFormatter(); - // This regex attempts to match a JSONP structure: - // * Any amount of whitespace (including unicode nonbreaking spaces) between the start of the file and the callback name - // * Callback name (any valid JavaScript function name according to ECMA-262 Edition 3 spec) - // * Any amount of whitespace (including unicode nonbreaking spaces) - // * Open parentheses - // * Any amount of whitespace (including unicode nonbreaking spaces) - // * Either { or [, the only two valid characters to start a JSON string. - // * Any character, any number of times - // * Either } or ], the only two valid closing characters of a JSON string. - // * Any amount of whitespace (including unicode nonbreaking spaces) - // * A closing parenthesis, an optional semicolon, and any amount of whitespace (including unicode nonbreaking spaces) until the end of the file. - // This will miss anything that has comments, or more than one callback, or requires modification before use. - var outputDoc = ''; - // text = text.match(jsonp_regex)[1]; - var cleanData = '', - callback = ''; - var callback_results = jsonp_regex.exec(this.data); - if (callback_results && callback_results.length === 3) { - if (this.debug) { console.log("THIS IS JSONp"); } - callback = callback_results[1]; - cleanData = callback_results[2]; - } else { - if (this.debug) { console.log("Vanilla JSON"); } - cleanData = this.data; - } - if (this.debug) { console.log(cleanData); } - // Covert, and catch exceptions on failure - try { - // var jsonObj = this.nativeJSON.decode(cleanData); - var jsonObj = JSON.parse(cleanData); - if (jsonObj) { - outputDoc = this.jsonFormatter.jsonToHTML(jsonObj, callback); - } else { - throw "There was no object!"; - } - } catch (e) { - if (this.debug) { console.log(e); } - outputDoc = this.jsonFormatter.errorPage(e, this.data); - } - var links = ''; - if (this.targetType !== undefined) { - this.idType = this.targetType; - this.id = this.target; - } - var el; - if (this.idType === "class") { - el = document.getElementsByClassName(this.id); - if (el) { - el.className += el.className ? ' jsonViewOutput' : 'jsonViewOutput'; - el.innerHTML = links + outputDoc; - } - } else if (this.idType === "id") { - el = document.getElementById(this.id); - if (el) { - el.className += el.className ? ' jsonViewOutput' : 'jsonViewOutput'; - el.innerHTML = links + outputDoc; - } - el.innerHTML = links + outputDoc; - } - var items = document.getElementsByClassName('collapsible'); - for (var i = 0; i < items.length; i++) { - addCollapser(items[i].parentNode); - } - } else { - // console.log("JSONView: this is not json, not formatting."); - } -} \ No newline at end of file diff --git a/library/admin/ReduxCore/assets/js/vendor/jsonview.min.js b/library/admin/ReduxCore/assets/js/vendor/jsonview.min.js deleted file mode 100644 index b8c4f1bb..00000000 --- a/library/admin/ReduxCore/assets/js/vendor/jsonview.min.js +++ /dev/null @@ -1,16 +0,0 @@ -/* global console, jsonView *//* - * ViewJSON - * Version 1.0 - * A Google Chrome extension to display JSON in a user-friendly format - * - * This is a chromeified version of the JSONView Firefox extension by Ben Hollis: - * http://jsonview.com - * http://code.google.com/p/jsonview - * - * Also based on the XMLTree Chrome extension by Moonty & alan.stroop - * https://chrome.google.com/extensions/detail/gbammbheopgpmaagmckhpjbfgdfkpadb - * - * port by Jamie Wilkinson (@jamiew) | http://jamiedubs.com | http://github.com/jamiew - * MIT license / copyfree (f) F.A.T. Lab http://fffff.at - * Speed Project Approved: 2h - */function collapse(e){var t=e.target,n=t.parentNode.getElementsByClassName("collapsible");if(!n.length)return;n=n[0];if(n.style.display==="none"){var r=n.parentNode.getElementsByClassName("ellipsis")[0];n.parentNode.removeChild(r),n.style.display=""}else{n.style.display="none";var r=document.createElement("span");r.className="ellipsis",r.innerHTML=" … ",n.parentNode.insertBefore(r,n)}t.innerHTML=t.innerHTML==="-"?"+":"-"}function addCollapser(e){if(e.nodeName!=="LI")return;var t=document.createElement("div");t.className="collapser",t.innerHTML="-",t.addEventListener("click",collapse,!1),e.insertBefore(t,e.firstChild)}function jsonView(e,t){this.debug=!1;if(e.indexOf("#")!==-1)this.idType="id",this.id=e.replace("#","");else{if(e.indexOf(".")===-1){this.debug&&console.log("Can't find that element");return}this.idType="class",this.id=e.replace(".","")}this.data=document.getElementById(this.id).innerHTML;if(typeof t!==undefined)if(t.indexOf("#")!==-1)this.targetType="id",this.target=t.replace("#","");else{if(e.indexOf(".")===-1){this.debug&&console.log("Can't find the target element");return}this.targetType="class",this.target=t.replace(".","")}/^\(.*)\<\/pre\>$/.test(this.data)&&(this.debug&&console.log("JSONView: data is wrapped in
    ...
    , stripping HTML..."),this.data=this.data.replace(/<(?:.|\s)*?>/g,""));var n=/^\s*([\[\{].*[\}\]])\s*$/,r=/^[\s\u200B\uFEFF]*([\w$\[\]\.]+)[\s\u200B\uFEFF]*\([\s\u200B\uFEFF]*([\[{][\s\S]*[\]}])[\s\u200B\uFEFF]*\);?[\s\u200B\uFEFF]*$/,i=/([\[\{][\s\S]*[\]\}])\)/,s=n.test(this.data),o=r.test(this.data);this.debug&&console.log("JSONView: is_json="+s+" is_jsonp="+o);if(s||o){this.debug&&console.log("JSONView: sexytime!");function u(){}u.prototype={htmlEncode:function(e){return e!=null?e.toString().replace(/&/g,"&").replace(/"/g,""").replace(//g,">"):""},decorateWithSpan:function(e,t){return''+this.htmlEncode(e)+""},valueToHTML:function(e){var t=typeof e,n="";return e===null?n+=this.decorateWithSpan("null","null"):e&&e.constructor===Array?n+=this.arrayToHTML(e):t==="object"?n+=this.objectToHTML(e):t==="number"?n+=this.decorateWithSpan(e,"num"):t==="string"?/^(http|https):\/\/[^\s]+$/.test(e)?n+=''+this.htmlEncode(e)+"":n+=this.decorateWithSpan('"'+e+'"',"string"):t==="boolean"&&(n+=this.decorateWithSpan(e,"bool")),n},arrayToHTML:function(e){var t='[
      ',n=!1;for(var r in e)n=!0,t+="
    • ",t+=this.valueToHTML(e[r]),t+="
    • ";return t+="
    ]",n||(t="[ ]"),t},objectToHTML:function(e){var t='{
      ',n=!1;for(var r in e)n=!0,t+="
    • ",t+=''+this.htmlEncode(r)+": ",t+=this.valueToHTML(e[r]),t+="
    • ";return t+="
    }",n||(t="{ }"),t},jsonToHTML:function(e,t,n){var r="";return t?(r+='
    '+t+" (
    ",r+='
    '):r+='
    ',r+=this.valueToHTML(e),r+="
    ",t&&(r+='
    )
    '),this.toHTML(r,n)},errorPage:function(e,t,n){var r='
    Error parsing JSON: '+e.message+"
    ";return r+="

    "+e.stack+":

    ",r+='
    '+this.htmlEncode(t)+"
    ",this.toHTML(r,n+" - Error")},toHTML:function(e){return e}},this.jsonFormatter=new u;var a="",f="",l="",c=r.exec(this.data);c&&c.length===3?(this.debug&&console.log("THIS IS JSONp"),l=c[1],f=c[2]):(this.debug&&console.log("Vanilla JSON"),f=this.data),this.debug&&console.log(f);try{var h=JSON.parse(f);if(!h)throw"There was no object!";a=this.jsonFormatter.jsonToHTML(h,l)}catch(p){this.debug&&console.log(p),a=this.jsonFormatter.errorPage(p,this.data)}var d="";this.targetType!==undefined&&(this.idType=this.targetType,this.id=this.target);var v;this.idType==="class"?(v=document.getElementsByClassName(this.id),v&&(v.className+=v.className?" jsonViewOutput":"jsonViewOutput",v.innerHTML=d+a)):this.idType==="id"&&(v=document.getElementById(this.id),v&&(v.className+=v.className?" jsonViewOutput":"jsonViewOutput",v.innerHTML=d+a),v.innerHTML=d+a);var m=document.getElementsByClassName("collapsible");for(var g=0;g' + entity + '' + html; - } - var icons = { - 'icon-move' : '', - 'icon-music' : '', - 'icon-network' : '', - 'icon-off' : '', - 'icon-ok' : '', - 'icon-ok-circle' : '', - 'icon-ok-sign' : '', - 'icon-paper-clip' : '', - 'icon-paper-clip-alt' : '', - 'icon-path' : '', - 'icon-plus-sign' : '', - 'icon-print' : '', - 'icon-qrcode' : '', - 'icon-question' : '', - 'icon-question-sign' : '', - 'icon-quotes' : '', - 'icon-quotes-alt' : '', - 'icon-random' : '', - 'icon-record' : '', - 'icon-reddit' : '', - 'icon-refresh' : '', - 'icon-screenshot' : '', - 'icon-search' : '', - 'icon-search-alt' : '', - 'icon-share' : '', - 'icon-share-alt' : '', - 'icon-shopping-cart' : '', - 'icon-shopping-cart-sign' : '', - 'icon-signal' : '', - 'icon-skype' : '', - 'icon-slideshare' : '', - 'icon-smiley' : '', - 'icon-th-large' : '', - 'icon-th-list' : '', - 'icon-thumbs-down' : '', - 'icon-thumbs-up' : '', - 'icon-time' : '', - 'icon-time-alt' : '', - 'icon-tint' : '', - 'icon-torso' : '', - 'icon-trash' : '', - 'icon-trash-alt' : '', - 'icon-tumblr' : '', - 'icon-w3c' : '', - 'icon-warning-sign' : '', - 'icon-website' : '', - 'icon-website-alt' : '', - 'icon-wheelchair' : '', - 'icon-wordpress' : '', - 'icon-wrench' : '', - 'icon-wrench-alt' : '', - 'icon-youtube' : '', - 'icon-zoom-in' : '', - 'icon-zoom-out' : '', - 'icon-pause-alt' : '', - 'icon-pencil' : '', - 'icon-pencil-alt' : '', - 'icon-person' : '', - 'icon-phone' : '', - 'icon-phone-alt' : '', - 'icon-photo' : '', - 'icon-photo-alt' : '', - 'icon-picasa' : '', - 'icon-picture' : '', - 'icon-pinterest' : '', - 'icon-plane' : '', - 'icon-play-alt' : '', - 'icon-play-circle' : '', - 'icon-plus' : '', - 'icon-remove' : '', - 'icon-remove-circle' : '', - 'icon-remove-sign' : '', - 'icon-repeat' : '', - 'icon-repeat-alt' : '', - 'icon-resize-full' : '', - 'icon-resize-horizontal' : '', - 'icon-resize-small' : '', - 'icon-resize-vertical' : '', - 'icon-retweet' : '', - 'icon-reverse-alt' : '', - 'icon-road' : '', - 'icon-rss' : '', - 'icon-screen' : '', - 'icon-screen-alt' : '', - 'icon-smiley-alt' : '', - 'icon-speaker' : '', - 'icon-stackoverflow' : '', - 'icon-star' : '', - 'icon-star-alt' : '', - 'icon-star-empty' : '', - 'icon-stop-alt' : '', - 'icon-stumbleupon' : '', - 'icon-tag' : '', - 'icon-tags' : '', - 'icon-tasks' : '', - 'icon-text-height' : '', - 'icon-text-width' : '', - 'icon-th' : '', - 'icon-twitter' : '', - 'icon-universal-access' : '', - 'icon-unlock' : '', - 'icon-unlock-alt' : '', - 'icon-upload' : '', - 'icon-user' : '', - 'icon-video' : '', - 'icon-video-alt' : '', - 'icon-video-chat' : '', - 'icon-view-mode' : '', - 'icon-vimeo' : '', - 'icon-vkontakte' : '', - 'icon-volume-down' : '', - 'icon-volume-off' : '', - 'icon-volume-up' : '', - 'icon-backward' : '', - 'icon-fast-backward' : '', - 'icon-fast-forward' : '', - 'icon-forward' : '', - 'icon-play' : '', - 'icon-step-backward' : '', - 'icon-step-forward' : '', - 'icon-briefcase' : '', - 'icon-bullhorn' : '', - 'icon-calendar' : '', - 'icon-calendar-sign' : '', - 'icon-address-book' : '', - 'icon-address-book-alt' : '', - 'icon-adjust' : '', - 'icon-adult' : '', - 'icon-align-center' : '', - 'icon-align-justify' : '', - 'icon-align-left' : '', - 'icon-align-right' : '', - 'icon-arrow-down' : '', - 'icon-arrow-left' : '', - 'icon-arrow-right' : '', - 'icon-arrow-up' : '', - 'icon-asl' : '', - 'icon-asterisk' : '', - 'icon-ban-circle' : '', - 'icon-barcode' : '', - 'icon-behance' : '', - 'icon-bell' : '', - 'icon-blind' : '', - 'icon-blogger' : '', - 'icon-bold' : '', - 'icon-book' : '', - 'icon-bookmark' : '', - 'icon-bookmark-empty' : '', - 'icon-braille' : '', - 'icon-camera' : '', - 'icon-cc' : '', - 'icon-certificate' : '', - 'icon-check' : '', - 'icon-check-empty' : '', - 'icon-chevron-down' : '', - 'icon-chevron-left' : '', - 'icon-chevron-right' : '', - 'icon-chevron-up' : '', - 'icon-child' : '', - 'icon-circle-arrow-down' : '', - 'icon-circle-arrow-left' : '', - 'icon-circle-arrow-right' : '', - 'icon-circle-arrow-up' : '', - 'icon-cloud' : '', - 'icon-cloud-alt' : '', - 'icon-cog' : '', - 'icon-cog-alt' : '', - 'icon-cogs' : '', - 'icon-comment' : '', - 'icon-comment-alt' : '', - 'icon-compass' : '', - 'icon-compass-alt' : '', - 'icon-credit-card' : '', - 'icon-css' : '', - 'icon-dashboard' : '', - 'icon-delicious' : '', - 'icon-deviantart' : '', - 'icon-digg' : '', - 'icon-download' : '', - 'icon-download-alt' : '', - 'icon-dribble' : '', - 'icon-edit' : '', - 'icon-eject' : '', - 'icon-envelope' : '', - 'icon-envelope-alt' : '', - 'icon-error' : '', - 'icon-error-alt' : '', - 'icon-exclamation-sign' : '', - 'icon-eye-close' : '', - 'icon-eye-open' : '', - 'icon-facebook' : '', - 'icon-facetime-video' : '', - 'icon-female' : '', - 'icon-file' : '', - 'icon-file-alt' : '', - 'icon-file-edit' : '', - 'icon-file-edit-alt' : '', - 'icon-file-new' : '', - 'icon-file-new-alt' : '', - 'icon-film' : '', - 'icon-filter' : '', - 'icon-fire' : '', - 'icon-flag' : '', - 'icon-flag-alt' : '', - 'icon-flickr' : '', - 'icon-folder' : '', - 'icon-folder-close' : '', - 'icon-folder-open' : '', - 'icon-folder-sign' : '', - 'icon-font' : '', - 'icon-fontsize' : '', - 'icon-forward-alt' : '', - 'icon-foursquare' : '', - 'icon-friendfeed' : '', - 'icon-friendfeed-rect' : '', - 'icon-fullscreen' : '', - 'icon-gift' : '', - 'icon-github' : '', - 'icon-github-text' : '', - 'icon-glass' : '', - 'icon-glasses' : '', - 'icon-globe' : '', - 'icon-globe-alt' : '', - 'icon-googleplus' : '', - 'icon-graph' : '', - 'icon-graph-alt' : '', - 'icon-group' : '', - 'icon-group-alt' : '', - 'icon-guidedog' : '', - 'icon-hand-down' : '', - 'icon-hand-left' : '', - 'icon-hand-right' : '', - 'icon-hand-up' : '', - 'icon-hdd' : '', - 'icon-headphones' : '', - 'icon-hearing-impaired' : '', - 'icon-heart' : '', - 'icon-heart-alt' : '', - 'icon-heart-empty' : '', - 'icon-home' : '', - 'icon-home-alt' : '', - 'icon-idea' : '', - 'icon-idea-alt' : '', - 'icon-inbox' : '', - 'icon-inbox-alt' : '', - 'icon-inbox-box' : '', - 'icon-indent-left' : '', - 'icon-indent-right' : '', - 'icon-info-sign' : '', - 'icon-instagram' : '', - 'icon-iphone-home' : '', - 'icon-italic' : '', - 'icon-key' : '', - 'icon-laptop' : '', - 'icon-laptop-alt' : '', - 'icon-leaf' : '', - 'icon-linkedin' : '', - 'icon-list' : '', - 'icon-list-alt' : '', - 'icon-lock' : '', - 'icon-lock-alt' : '', - 'icon-magnet' : '', - 'icon-male' : '', - 'icon-map-marker' : '', - 'icon-map-marker-alt' : '', - 'icon-mic' : '', - 'icon-mic-alt' : '', - 'icon-minus' : '', - 'icon-minus-sign' : '', - 'icon-pause' : '', - 'icon-fork' : '', - 'icon-broom' : '', - 'icon-return-key' : '', - 'icon-lastfm' : '', - 'icon-livejournal' : '', - 'icon-myspace' : '', - 'icon-soundcloud' : '', - 'icon-viadeo' : '', - 'icon-spotify' : '', - 'icon-caret-left' : '', - 'icon-caret-up' : '', - 'icon-caret-right' : '', - 'icon-caret-down' : '', - 'icon-stop' : '' - }, - els = document.getElementsByTagName('*'), - i, attr, html, c, el; - for (i = 0; ; i += 1) { - el = els[i]; - if(!el) { - break; - } - attr = el.getAttribute('data-icon'); - if (attr) { - addIcon(el, attr); - } - c = el.className; - c = c.match(/icon-[^\s'"]+/); - if (c && icons[c[0]]) { - addIcon(el, icons[c[0]]); - } - } -}; \ No newline at end of file diff --git a/library/admin/ReduxCore/assets/js/vendor/qtip/jquery.qtip.js b/library/admin/ReduxCore/assets/js/vendor/qtip/jquery.qtip.js deleted file mode 100644 index dfec8b8e..00000000 --- a/library/admin/ReduxCore/assets/js/vendor/qtip/jquery.qtip.js +++ /dev/null @@ -1,3951 +0,0 @@ -/* - * qTip2 - Pretty powerful tooltips - v2.2.0 - * http://qtip2.com - * - * Copyright (c) 2013 Craig Michael Thompson - * Released under the MIT, GPL licenses - * http://jquery.org/license - * - * Date: Thu Nov 21 2013 08:34 GMT+0000 - * Plugins: tips modal viewport svg imagemap ie6 - * Styles: basic css3 - */ -/*global window: false, jQuery: false, console: false, define: false */ - -if ( typeof jQuery.qtip === 'undefined' ) { - /* Cache window, document, undefined */ - (function( window, document, undefined ) { - - // Uses AMD or browser globals to create a jQuery plugin. - (function( factory ) { - "use strict"; - if ( typeof define === 'function' && define.amd ) { - define( ['jquery'], factory ); - } - else if ( jQuery && !jQuery.fn.qtip ) { - factory( jQuery ); - } - } - ( - function( $ ) { - "use strict"; // Enable ECMAScript "strict" operation for this function. See more: http://ejohn.org/blog/ecmascript-5-strict-mode-json-and-more/ - - ;// Munge the primitives - Paul Irish tip - var TRUE = true, - FALSE = false, - NULL = null, - - // Common variables - X = 'x', Y = 'y', - WIDTH = 'width', - HEIGHT = 'height', - - // Positioning sides - TOP = 'top', - LEFT = 'left', - BOTTOM = 'bottom', - RIGHT = 'right', - CENTER = 'center', - - // Position adjustment types - FLIP = 'flip', - FLIPINVERT = 'flipinvert', - SHIFT = 'shift', - - // Shortcut vars - QTIP, PROTOTYPE, CORNER, CHECKS, - PLUGINS = {}, - NAMESPACE = 'qtip', - ATTR_HAS = 'data-hasqtip', - ATTR_ID = 'data-qtip-id', - WIDGET = ['ui-widget', 'ui-tooltip'], - SELECTOR = '.' + NAMESPACE, - INACTIVE_EVENTS = 'click dblclick mousedown mouseup mousemove mouseleave mouseenter'.split( ' ' ), - - CLASS_FIXED = NAMESPACE + '-fixed', - CLASS_DEFAULT = NAMESPACE + '-default', - CLASS_FOCUS = NAMESPACE + '-focus', - CLASS_HOVER = NAMESPACE + '-hover', - CLASS_DISABLED = NAMESPACE + '-disabled', - - replaceSuffix = '_replacedByqTip', - oldtitle = 'oldtitle', - trackingBound, - - // Browser detection - BROWSER = { - /* - * IE version detection - * - * Adapted from: http://ajaxian.com/archives/attack-of-the-ie-conditional-comment - * Credit to James Padolsey for the original implemntation! - */ - ie: (function() { - var v = 3, div = document.createElement( 'div' ); - while ( (div.innerHTML = '') ) { - if ( !div.getElementsByTagName( 'i' )[0] ) { - break; - } - } - return v > 4 ? v : NaN; - }()), - - /* - * iOS version detection - */ - iOS: parseFloat( - ('' + (/CPU.*OS ([0-9_]{1,5})|(CPU like).*AppleWebKit.*Mobile/i.exec( navigator.userAgent ) || [0, ''])[1]) - .replace( 'undefined', '3_2' ).replace( '_', '.' ).replace( '_', '' ) - ) || FALSE - }; - - ; - function QTip( target, options, id, attr ) { - // Elements and ID - this.id = id; - this.target = target; - this.tooltip = NULL; - this.elements = {target: target}; - - // Internal constructs - this._id = NAMESPACE + '-' + id; - this.timers = {img: {}}; - this.options = options; - this.plugins = {}; - - // Cache object - this.cache = { - event: {}, - target: $(), - disabled: FALSE, - attr: attr, - onTooltip: FALSE, - lastClass: '' - }; - - // Set the initial flags - this.rendered = this.destroyed = this.disabled = this.waiting = - this.hiddenDuringWait = this.positioning = this.triggering = FALSE; - } - - PROTOTYPE = QTip.prototype; - - PROTOTYPE._when = function( deferreds ) { - return $.when.apply( $, deferreds ); - }; - - PROTOTYPE.render = function( show ) { - if ( this.rendered || this.destroyed ) { - return this; - } // If tooltip has already been rendered, exit - - var self = this, - options = this.options, - cache = this.cache, - elements = this.elements, - text = options.content.text, - title = options.content.title, - button = options.content.button, - posOptions = options.position, - namespace = '.' + this._id + ' ', - deferreds = [], - tooltip; - - // Add ARIA attributes to target - $.attr( this.target[0], 'aria-describedby', this._id ); - - // Create tooltip element - this.tooltip = elements.tooltip = tooltip = $( - '
    ', { - 'id': this._id, - 'class': [NAMESPACE, CLASS_DEFAULT, options.style.classes, NAMESPACE + '-pos-' + options.position.my.abbrev()].join( ' ' ), - 'width': options.style.width || '', - 'height': options.style.height || '', - 'tracking': posOptions.target === 'mouse' && posOptions.adjust.mouse, - - /* ARIA specific attributes */ - 'role': 'alert', - 'aria-live': 'polite', - 'aria-atomic': FALSE, - 'aria-describedby': this._id + '-content', - 'aria-hidden': TRUE - } - ) - .toggleClass( CLASS_DISABLED, this.disabled ) - .attr( ATTR_ID, this.id ) - .data( NAMESPACE, this ) - .appendTo( posOptions.container ) - .append( - // Create content element - elements.content = $( - '
    ', { - 'class': NAMESPACE + '-content', - 'id': this._id + '-content', - 'aria-atomic': TRUE - } - ) - ); - - // Set rendered flag and prevent redundant reposition calls for now - this.rendered = -1; - this.positioning = TRUE; - - // Create title... - if ( title ) { - - this._createTitle(); - - // Update title only if its not a callback (called in toggle if so) - if ( !$.isFunction( title ) ) { - deferreds.push( this._updateTitle( title, FALSE ) ); - } - } - - // Create button - if ( button ) { - this._createButton(); - } - - // Set proper rendered flag and update content if not a callback function (called in toggle) - if ( !$.isFunction( text ) ) { - deferreds.push( this._updateContent( text, FALSE ) ); - } - this.rendered = TRUE; - - // Setup widget classes - this._setWidget(); - - // Initialize 'render' plugins - $.each( - PLUGINS, function( name ) { - var instance; - if ( this.initialize === 'render' && (instance = this( self )) ) { - self.plugins[name] = instance; - } - } - ); - - // Unassign initial events and assign proper events - this._unassignEvents(); - this._assignEvents(); - - // When deferreds have completed - this._when( deferreds ).then( - function() { - // tooltiprender event - self._trigger( 'render' ); - - // Reset flags - self.positioning = FALSE; - - // Show tooltip if not hidden during wait period - if ( !self.hiddenDuringWait && (options.show.ready || show) ) { - self.toggle( TRUE, cache.event, FALSE ); - } - self.hiddenDuringWait = FALSE; - } - ); - - // Expose API - QTIP.api[this.id] = this; - - return this; - }; - - PROTOTYPE.destroy = function( immediate ) { - // Set flag the signify destroy is taking place to plugins - // and ensure it only gets destroyed once! - if ( this.destroyed ) { - return this.target; - } - - function process() { - if ( this.destroyed ) { - return; - } - this.destroyed = TRUE; - - var target = this.target, - title = target.attr( oldtitle ); - - // Destroy tooltip if rendered - if ( this.rendered ) { - this.tooltip.stop( 1, 0 ).find( '*' ).remove().end().remove(); - } - - // Destroy all plugins - $.each( - this.plugins, function( name ) { - this.destroy && this.destroy(); - } - ); - - // Clear timers and remove bound events - clearTimeout( this.timers.show ); - clearTimeout( this.timers.hide ); - this._unassignEvents(); - - // Remove api object and ARIA attributes - target.removeData( NAMESPACE ) - .removeAttr( ATTR_ID ) - .removeAttr( ATTR_HAS ) - .removeAttr( 'aria-describedby' ); - - // Reset old title attribute if removed - if ( this.options.suppress && title ) { - target.attr( 'title', title ).removeAttr( oldtitle ); - } - - // Remove qTip events associated with this API - this._unbind( target ); - - // Remove ID from used id objects, and delete object references - // for better garbage collection and leak protection - this.options = this.elements = this.cache = this.timers = - this.plugins = this.mouse = NULL; - - // Delete epoxsed API object - delete QTIP.api[this.id]; - } - - // If an immediate destory is needed - if ( (immediate !== TRUE || this.triggering === 'hide') && this.rendered ) { - this.tooltip.one( 'tooltiphidden', $.proxy( process, this ) ); - !this.triggering && this.hide(); - } - - // If we're not in the process of hiding... process - else { - process.call( this ); - } - - return this.target; - }; - - ; - function invalidOpt( a ) { - return a === NULL || $.type( a ) !== 'object'; - } - - function invalidContent( c ) { - return !( $.isFunction( c ) || (c && c.attr) || c.length || ($.type( c ) === 'object' && (c.jquery || c.then) )); - } - - // Option object sanitizer - function sanitizeOptions( opts ) { - var content, text, ajax, once; - - if ( invalidOpt( opts ) ) { - return FALSE; - } - - if ( invalidOpt( opts.metadata ) ) { - opts.metadata = {type: opts.metadata}; - } - - if ( 'content' in opts ) { - content = opts.content; - - if ( invalidOpt( content ) || content.jquery || content.done ) { - content = opts.content = { - text: (text = invalidContent( content ) ? FALSE : content) - }; - } - else { - text = content.text; - } - - // DEPRECATED - Old content.ajax plugin functionality - // Converts it into the proper Deferred syntax - if ( 'ajax' in content ) { - ajax = content.ajax; - once = ajax && ajax.once !== FALSE; - delete content.ajax; - - content.text = function( event, api ) { - var loading = text || $( this ).attr( api.options.content.attr ) || 'Loading...', - - deferred = $.ajax( - $.extend( {}, ajax, {context: api} ) - ) - .then( ajax.success, NULL, ajax.error ) - .then( - function( content ) { - if ( content && once ) { - api.set( 'content.text', content ); - } - return content; - }, - function( xhr, status, error ) { - if ( api.destroyed || xhr.status === 0 ) { - return; - } - api.set( 'content.text', status + ': ' + error ); - } - ); - - return !once ? (api.set( 'content.text', loading ), deferred) : loading; - }; - } - - if ( 'title' in content ) { - if ( !invalidOpt( content.title ) ) { - content.button = content.title.button; - content.title = content.title.text; - } - - if ( invalidContent( content.title || FALSE ) ) { - content.title = FALSE; - } - } - } - - if ( 'position' in opts && invalidOpt( opts.position ) ) { - opts.position = {my: opts.position, at: opts.position}; - } - - if ( 'show' in opts && invalidOpt( opts.show ) ) { - opts.show = opts.show.jquery ? {target: opts.show} : - opts.show === TRUE ? {ready: TRUE} : {event: opts.show}; - } - - if ( 'hide' in opts && invalidOpt( opts.hide ) ) { - opts.hide = opts.hide.jquery ? {target: opts.hide} : {event: opts.hide}; - } - - if ( 'style' in opts && invalidOpt( opts.style ) ) { - opts.style = {classes: opts.style}; - } - - // Sanitize plugin options - $.each( - PLUGINS, function() { - this.sanitize && this.sanitize( opts ); - } - ); - - return opts; - } - - // Setup builtin .set() option checks - CHECKS = PROTOTYPE.checks = { - builtin: { - // Core checks - '^id$': function( obj, o, v, prev ) { - var id = v === TRUE ? QTIP.nextid : v, - new_id = NAMESPACE + '-' + id; - - if ( id !== FALSE && id.length > 0 && !$( '#' + new_id ).length ) { - this._id = new_id; - - if ( this.rendered ) { - this.tooltip[0].id = this._id; - this.elements.content[0].id = this._id + '-content'; - this.elements.title[0].id = this._id + '-title'; - } - } - else { - obj[o] = prev; - } - }, - '^prerender': function( obj, o, v ) { - v && !this.rendered && this.render( this.options.show.ready ); - }, - - // Content checks - '^content.text$': function( obj, o, v ) { - this._updateContent( v ); - }, - '^content.attr$': function( obj, o, v, prev ) { - if ( this.options.content.text === this.target.attr( prev ) ) { - this._updateContent( this.target.attr( v ) ); - } - }, - '^content.title$': function( obj, o, v ) { - - // Remove title if content is null - if ( !v ) { - return this._removeTitle(); - } - - // If title isn't already created, create it now and update - v && !this.elements.title && this._createTitle(); - this._updateTitle( v ); - }, - '^content.button$': function( obj, o, v ) { - this._updateButton( v ); - }, - '^content.title.(text|button)$': function( obj, o, v ) { - this.set( 'content.' + o, v ); // Backwards title.text/button compat - }, - - // Position checks - '^position.(my|at)$': function( obj, o, v ) { - 'string' === typeof v && (obj[o] = new CORNER( v, o === 'at' )); - }, - '^position.container$': function( obj, o, v ) { - this.rendered && this.tooltip.appendTo( v ); - }, - - // Show checks - '^show.ready$': function( obj, o, v ) { - v && (!this.rendered && this.render( TRUE ) || this.toggle( TRUE )); - }, - - // Style checks - '^style.classes$': function( obj, o, v, p ) { - this.rendered && this.tooltip.removeClass( p ).addClass( v ); - }, - '^style.(width|height)': function( obj, o, v ) { - this.rendered && this.tooltip.css( o, v ); - }, - '^style.widget|content.title': function() { - this.rendered && this._setWidget(); - }, - '^style.def': function( obj, o, v ) { - this.rendered && this.tooltip.toggleClass( CLASS_DEFAULT, !!v ); - }, - - // Events check - '^events.(render|show|move|hide|focus|blur)$': function( obj, o, v ) { - this.rendered && this.tooltip[($.isFunction( v ) ? '' : 'un') + 'bind']( 'tooltip' + o, v ); - }, - - // Properties which require event reassignment - '^(show|hide|position).(event|target|fixed|inactive|leave|distance|viewport|adjust)': function() { - if ( !this.rendered ) { - return; - } - - // Set tracking flag - var posOptions = this.options.position; - this.tooltip.attr( 'tracking', posOptions.target === 'mouse' && posOptions.adjust.mouse ); - - // Reassign events - this._unassignEvents(); - this._assignEvents(); - } - } - }; - - // Dot notation converter - function convertNotation( options, notation ) { - var i = 0, obj, option = options, - - // Split notation into array - levels = notation.split( '.' ); - - // Loop through - while ( option = option[levels[i++]] ) { - if ( i < levels.length ) { - obj = option; - } - } - - return [obj || options, levels.pop()]; - } - - PROTOTYPE.get = function( notation ) { - if ( this.destroyed ) { - return this; - } - - var o = convertNotation( this.options, notation.toLowerCase() ), - result = o[0][o[1]]; - - return result.precedance ? result.string() : result; - }; - - function setCallback( notation, args ) { - var category, rule, match; - - for ( category in this.checks ) { - for ( rule in this.checks[category] ) { - if ( match = (new RegExp( rule, 'i' )).exec( notation ) ) { - args.push( match ); - - if ( category === 'builtin' || this.plugins[category] ) { - this.checks[category][rule].apply( - this.plugins[category] || this, args - ); - } - } - } - } - } - - var rmove = /^position\.(my|at|adjust|target|container|viewport)|style|content|show\.ready/i, - rrender = /^prerender|show\.ready/i; - - PROTOTYPE.set = function( option, value ) { - if ( this.destroyed ) { - return this; - } - - var rendered = this.rendered, - reposition = FALSE, - options = this.options, - checks = this.checks, - name; - - // Convert singular option/value pair into object form - if ( 'string' === typeof option ) { - name = option; - option = {}; - option[name] = value; - } - else { - option = $.extend( {}, option ); - } - - // Set all of the defined options to their new values - $.each( - option, function( notation, value ) { - if ( rendered && rrender.test( notation ) ) { - delete option[notation]; - return; - } - - // Set new obj value - var obj = convertNotation( options, notation.toLowerCase() ), previous; - previous = obj[0][obj[1]]; - obj[0][obj[1]] = value && value.nodeType ? $( value ) : value; - - // Also check if we need to reposition - reposition = rmove.test( notation ) || reposition; - - // Set the new params for the callback - option[notation] = [obj[0], obj[1], value, previous]; - } - ); - - // Re-sanitize options - sanitizeOptions( options ); - - /* - * Execute any valid callbacks for the set options - * Also set positioning flag so we don't get loads of redundant repositioning calls. - */ - this.positioning = TRUE; - $.each( option, $.proxy( setCallback, this ) ); - this.positioning = FALSE; - - // Update position if needed - if ( this.rendered && this.tooltip[0].offsetWidth > 0 && reposition ) { - this.reposition( options.position.target === 'mouse' ? NULL : this.cache.event ); - } - - return this; - }; - - ; - PROTOTYPE._update = function( content, element, reposition ) { - var self = this, - cache = this.cache; - - // Make sure tooltip is rendered and content is defined. If not return - if ( !this.rendered || !content ) { - return FALSE; - } - - // Use function to parse content - if ( $.isFunction( content ) ) { - content = content.call( this.elements.target, cache.event, this ) || ''; - } - - // Handle deferred content - if ( $.isFunction( content.then ) ) { - cache.waiting = TRUE; - return content.then( - function( c ) { - cache.waiting = FALSE; - return self._update( c, element ); - }, NULL, function( e ) { - return self._update( e, element ); - } - ); - } - - // If content is null... return false - if ( content === FALSE || (!content && content !== '') ) { - return FALSE; - } - - // Append new content if its a DOM array and show it if hidden - if ( content.jquery && content.length > 0 ) { - element.empty().append( - content.css( {display: 'block', visibility: 'visible'} ) - ); - } - - // Content is a regular string, insert the new content - else { - element.html( content ); - } - - // Wait for content to be loaded, and reposition - return this._waitForContent( element ).then( - function( images ) { - if ( images.images && images.images.length && self.rendered && self.tooltip[0].offsetWidth > 0 ) { - self.reposition( cache.event, !images.length ); - } - } - ); - }; - - PROTOTYPE._waitForContent = function( element ) { - var cache = this.cache; - - // Set flag - cache.waiting = TRUE; - - // If imagesLoaded is included, ensure images have loaded and return promise - return ( $.fn.imagesLoaded ? element.imagesLoaded() : $.Deferred().resolve( [] ) ) - .done( - function() { - cache.waiting = FALSE; - } - ) - .promise(); - }; - - PROTOTYPE._updateContent = function( content, reposition ) { - this._update( content, this.elements.content, reposition ); - }; - - PROTOTYPE._updateTitle = function( content, reposition ) { - if ( this._update( content, this.elements.title, reposition ) === FALSE ) { - this._removeTitle( FALSE ); - } - }; - - PROTOTYPE._createTitle = function() { - var elements = this.elements, - id = this._id + '-title'; - - // Destroy previous title element, if present - if ( elements.titlebar ) { - this._removeTitle(); - } - - // Create title bar and title elements - elements.titlebar = $( - '
    ', { - 'class': NAMESPACE + '-titlebar ' + (this.options.style.widget ? createWidgetClass( 'header' ) : '') - } - ) - .append( - elements.title = $( - '
    ', { - 'id': id, - 'class': NAMESPACE + '-title', - 'aria-atomic': TRUE - } - ) - ) - .insertBefore( elements.content ) - - // Button-specific events - .delegate( - '.qtip-close', 'mousedown keydown mouseup keyup mouseout', function( event ) { - $( this ).toggleClass( - 'ui-state-active ui-state-focus', event.type.substr( -4 ) === 'down' - ); - } - ) - .delegate( - '.qtip-close', 'mouseover mouseout', function( event ) { - $( this ).toggleClass( 'ui-state-hover', event.type === 'mouseover' ); - } - ); - - // Create button if enabled - if ( this.options.content.button ) { - this._createButton(); - } - }; - - PROTOTYPE._removeTitle = function( reposition ) { - var elements = this.elements; - - if ( elements.title ) { - elements.titlebar.remove(); - elements.titlebar = elements.title = elements.button = NULL; - - // Reposition if enabled - if ( reposition !== FALSE ) { - this.reposition(); - } - } - }; - - ; - PROTOTYPE.reposition = function( event, effect ) { - if ( !this.rendered || this.positioning || this.destroyed ) { - return this; - } - - // Set positioning flag - this.positioning = TRUE; - - var cache = this.cache, - tooltip = this.tooltip, - posOptions = this.options.position, - target = posOptions.target, - my = posOptions.my, - at = posOptions.at, - viewport = posOptions.viewport, - container = posOptions.container, - adjust = posOptions.adjust, - method = adjust.method.split( ' ' ), - tooltipWidth = tooltip.outerWidth( FALSE ), - tooltipHeight = tooltip.outerHeight( FALSE ), - targetWidth = 0, - targetHeight = 0, - type = tooltip.css( 'position' ), - position = {left: 0, top: 0}, - visible = tooltip[0].offsetWidth > 0, - isScroll = event && event.type === 'scroll', - win = $( window ), - doc = container[0].ownerDocument, - mouse = this.mouse, - pluginCalculations, offset; - - // Check if absolute position was passed - if ( $.isArray( target ) && target.length === 2 ) { - // Force left top and set position - at = {x: LEFT, y: TOP}; - position = {left: target[0], top: target[1]}; - } - - // Check if mouse was the target - else if ( target === 'mouse' ) { - // Force left top to allow flipping - at = {x: LEFT, y: TOP}; - - // Use the cached mouse coordinates if available, or passed event has no coordinates - if ( mouse && mouse.pageX && (adjust.mouse || !event || !event.pageX) ) { - event = mouse; - } - - // If the passed event has no coordinates (such as a scroll event) - else if ( !event || !event.pageX ) { - // Use the mouse origin that caused the show event, if distance hiding is enabled - if ( (!adjust.mouse || this.options.show.distance) && cache.origin && cache.origin.pageX ) { - event = cache.origin; - } - - // Use cached event for resize/scroll events - else if ( !event || (event && (event.type === 'resize' || event.type === 'scroll')) ) { - event = cache.event; - } - } - - // Calculate body and container offset and take them into account below - if ( type !== 'static' ) { - position = container.offset(); - } - if ( doc.body.offsetWidth !== (window.innerWidth || doc.documentElement.clientWidth) ) { - offset = $( document.body ).offset(); - } - - // Use event coordinates for position - position = { - left: event.pageX - position.left + (offset && offset.left || 0), - top: event.pageY - position.top + (offset && offset.top || 0) - }; - - // Scroll events are a pain, some browsers - if ( adjust.mouse && isScroll && mouse ) { - position.left -= (mouse.scrollX || 0) - win.scrollLeft(); - position.top -= (mouse.scrollY || 0) - win.scrollTop(); - } - } - - // Target wasn't mouse or absolute... - else { - // Check if event targetting is being used - if ( target === 'event' ) { - if ( event && event.target && event.type !== 'scroll' && event.type !== 'resize' ) { - cache.target = $( event.target ); - } - else if ( !event.target ) { - cache.target = this.elements.target; - } - } - else if ( target !== 'event' ) { - cache.target = $( target.jquery ? target : this.elements.target ); - } - target = cache.target; - - // Parse the target into a jQuery object and make sure there's an element present - target = $( target ).eq( 0 ); - if ( target.length === 0 ) { - return this; - } - - // Check if window or document is the target - else if ( target[0] === document || target[0] === window ) { - targetWidth = BROWSER.iOS ? window.innerWidth : target.width(); - targetHeight = BROWSER.iOS ? window.innerHeight : target.height(); - - if ( target[0] === window ) { - position = { - top: (viewport || target).scrollTop(), - left: (viewport || target).scrollLeft() - }; - } - } - - // Check if the target is an element - else if ( PLUGINS.imagemap && target.is( 'area' ) ) { - pluginCalculations = PLUGINS.imagemap( - this, target, at, PLUGINS.viewport ? method : FALSE - ); - } - - // Check if the target is an SVG element - else if ( PLUGINS.svg && target && target[0].ownerSVGElement ) { - pluginCalculations = PLUGINS.svg( this, target, at, PLUGINS.viewport ? method : FALSE ); - } - - // Otherwise use regular jQuery methods - else { - targetWidth = target.outerWidth( FALSE ); - targetHeight = target.outerHeight( FALSE ); - position = target.offset(); - } - - // Parse returned plugin values into proper variables - if ( pluginCalculations ) { - targetWidth = pluginCalculations.width; - targetHeight = pluginCalculations.height; - offset = pluginCalculations.offset; - position = pluginCalculations.position; - } - - // Adjust position to take into account offset parents - position = this.reposition.offset( target, position, container ); - - // Adjust for position.fixed tooltips (and also iOS scroll bug in v3.2-4.0 & v4.3-4.3.2) - if ( (BROWSER.iOS > 3.1 && BROWSER.iOS < 4.1) || - (BROWSER.iOS >= 4.3 && BROWSER.iOS < 4.33) || - (!BROWSER.iOS && type === 'fixed') - ) { - position.left -= win.scrollLeft(); - position.top -= win.scrollTop(); - } - - // Adjust position relative to target - if ( !pluginCalculations || (pluginCalculations && pluginCalculations.adjustable !== FALSE) ) { - position.left += at.x === RIGHT ? targetWidth : at.x === CENTER ? targetWidth / 2 : 0; - position.top += at.y === BOTTOM ? targetHeight : at.y === CENTER ? targetHeight / 2 : 0; - } - } - - // Adjust position relative to tooltip - position.left += adjust.x + (my.x === RIGHT ? -tooltipWidth : my.x === CENTER ? -tooltipWidth / 2 : 0); - position.top += adjust.y + (my.y === BOTTOM ? -tooltipHeight : my.y === CENTER ? -tooltipHeight / 2 : 0); - - // Use viewport adjustment plugin if enabled - if ( PLUGINS.viewport ) { - position.adjusted = PLUGINS.viewport( - this, position, posOptions, targetWidth, targetHeight, tooltipWidth, tooltipHeight - ); - - // Apply offsets supplied by positioning plugin (if used) - if ( offset && position.adjusted.left ) { - position.left += offset.left; - } - if ( offset && position.adjusted.top ) { - position.top += offset.top; - } - } - - // Viewport adjustment is disabled, set values to zero - else { - position.adjusted = {left: 0, top: 0}; - } - - // tooltipmove event - if ( !this._trigger( 'move', [position, viewport.elem || viewport], event ) ) { - return this; - } - delete position.adjusted; - - // If effect is disabled, target it mouse, no animation is defined or positioning gives NaN out, set CSS directly - if ( effect === FALSE || !visible || isNaN( position.left ) || isNaN( position.top ) || target === 'mouse' || !$.isFunction( posOptions.effect ) ) { - tooltip.css( position ); - } - - // Use custom function if provided - else if ( $.isFunction( posOptions.effect ) ) { - posOptions.effect.call( tooltip, this, $.extend( {}, position ) ); - tooltip.queue( - function( next ) { - // Reset attributes to avoid cross-browser rendering bugs - $( this ).css( {opacity: '', height: ''} ); - if ( BROWSER.ie ) { - this.style.removeAttribute( 'filter' ); - } - - next(); - } - ); - } - - // Set positioning flag - this.positioning = FALSE; - - return this; - }; - - // Custom (more correct for qTip!) offset calculator - PROTOTYPE.reposition.offset = function( elem, pos, container ) { - if ( !container[0] ) { - return pos; - } - - var ownerDocument = $( elem[0].ownerDocument ), - quirks = !!BROWSER.ie && document.compatMode !== 'CSS1Compat', - parent = container[0], - scrolled, position, parentOffset, overflow; - - function scroll( e, i ) { - pos.left += i * e.scrollLeft(); - pos.top += i * e.scrollTop(); - } - - // Compensate for non-static containers offset - do { - if ( (position = $.css( parent, 'position' )) !== 'static' ) { - if ( position === 'fixed' ) { - parentOffset = parent.getBoundingClientRect(); - scroll( ownerDocument, -1 ); - } - else { - parentOffset = $( parent ).position(); - parentOffset.left += (parseFloat( $.css( parent, 'borderLeftWidth' ) ) || 0); - parentOffset.top += (parseFloat( $.css( parent, 'borderTopWidth' ) ) || 0); - } - - pos.left -= parentOffset.left + (parseFloat( $.css( parent, 'marginLeft' ) ) || 0); - pos.top -= parentOffset.top + (parseFloat( $.css( parent, 'marginTop' ) ) || 0); - - // If this is the first parent element with an overflow of "scroll" or "auto", store it - if ( !scrolled && (overflow = $.css( - parent, 'overflow' - )) !== 'hidden' && overflow !== 'visible' ) { - scrolled = $( parent ); - } - } - } - while ( (parent = parent.offsetParent) ); - - // Compensate for containers scroll if it also has an offsetParent (or in IE quirks mode) - if ( scrolled && (scrolled[0] !== ownerDocument[0] || quirks) ) { - scroll( scrolled, 1 ); - } - - return pos; - }; - - // Corner class - var C = (CORNER = PROTOTYPE.reposition.Corner = function( corner, forceY ) { - corner = ('' + corner).replace( /([A-Z])/, ' $1' ).replace( /middle/gi, CENTER ).toLowerCase(); - this.x = (corner.match( /left|right/i ) || corner.match( /center/ ) || ['inherit'])[0].toLowerCase(); - this.y = (corner.match( /top|bottom|center/i ) || ['inherit'])[0].toLowerCase(); - this.forceY = !!forceY; - - var f = corner.charAt( 0 ); - this.precedance = (f === 't' || f === 'b' ? Y : X); - }).prototype; - - C.invert = function( z, center ) { - this[z] = this[z] === LEFT ? RIGHT : this[z] === RIGHT ? LEFT : center || this[z]; - }; - - C.string = function() { - var x = this.x, y = this.y; - return x === y ? x : this.precedance === Y || (this.forceY && y !== 'center') ? y + ' ' + x : x + ' ' + y; - }; - - C.abbrev = function() { - var result = this.string().split( ' ' ); - return result[0].charAt( 0 ) + (result[1] && result[1].charAt( 0 ) || ''); - }; - - C.clone = function() { - return new CORNER( this.string(), this.forceY ); - }; - ; - PROTOTYPE.toggle = function( state, event ) { - var cache = this.cache, - options = this.options, - tooltip = this.tooltip; - - // Try to prevent flickering when tooltip overlaps show element - if ( event ) { - if ( (/over|enter/).test( event.type ) && (/out|leave/).test( cache.event.type ) && - options.show.target.add( event.target ).length === options.show.target.length && - tooltip.has( event.relatedTarget ).length ) { - return this; - } - - // Cache event - cache.event = cloneEvent( event ); - } - - // If we're currently waiting and we've just hidden... stop it - this.waiting && !state && (this.hiddenDuringWait = TRUE); - - // Render the tooltip if showing and it isn't already - if ( !this.rendered ) { - return state ? this.render( 1 ) : this; - } - else if ( this.destroyed || this.disabled ) { - return this; - } - - var type = state ? 'show' : 'hide', - opts = this.options[type], - otherOpts = this.options[!state ? 'show' : 'hide'], - posOptions = this.options.position, - contentOptions = this.options.content, - width = this.tooltip.css( 'width' ), - visible = this.tooltip.is( ':visible' ), - animate = state || opts.target.length === 1, - sameTarget = !event || opts.target.length < 2 || cache.target[0] === event.target, - identicalState, allow, showEvent, delay, after; - - // Detect state if valid one isn't provided - if ( (typeof state).search( 'boolean|number' ) ) { - state = !visible; - } - - // Check if the tooltip is in an identical state to the new would-be state - identicalState = !tooltip.is( ':animated' ) && visible === state && sameTarget; - - // Fire tooltip(show/hide) event and check if destroyed - allow = !identicalState ? !!this._trigger( type, [90] ) : NULL; - - // Check to make sure the tooltip wasn't destroyed in the callback - if ( this.destroyed ) { - return this; - } - - // If the user didn't stop the method prematurely and we're showing the tooltip, focus it - if ( allow !== FALSE && state ) { - this.focus( event ); - } - - // If the state hasn't changed or the user stopped it, return early - if ( !allow || identicalState ) { - return this; - } - - // Set ARIA hidden attribute - $.attr( tooltip[0], 'aria-hidden', !!!state ); - - // Execute state specific properties - if ( state ) { - // Store show origin coordinates - cache.origin = cloneEvent( this.mouse ); - - // Update tooltip content & title if it's a dynamic function - if ( $.isFunction( contentOptions.text ) ) { - this._updateContent( contentOptions.text, FALSE ); - } - if ( $.isFunction( contentOptions.title ) ) { - this._updateTitle( contentOptions.title, FALSE ); - } - - // Cache mousemove events for positioning purposes (if not already tracking) - if ( !trackingBound && posOptions.target === 'mouse' && posOptions.adjust.mouse ) { - $( document ).bind( 'mousemove.' + NAMESPACE, this._storeMouse ); - trackingBound = TRUE; - } - - // Update the tooltip position (set width first to prevent viewport/max-width issues) - if ( !width ) { - tooltip.css( 'width', tooltip.outerWidth( FALSE ) ); - } - this.reposition( event, arguments[2] ); - if ( !width ) { - tooltip.css( 'width', '' ); - } - - // Hide other tooltips if tooltip is solo - if ( !!opts.solo ) { - (typeof opts.solo === 'string' ? $( opts.solo ) : $( SELECTOR, opts.solo )) - .not( tooltip ).not( opts.target ).qtip( 'hide', $.Event( 'tooltipsolo' ) ); - } - } - else { - // Clear show timer if we're hiding - clearTimeout( this.timers.show ); - - // Remove cached origin on hide - delete cache.origin; - - // Remove mouse tracking event if not needed (all tracking qTips are hidden) - if ( trackingBound && !$( - SELECTOR + '[tracking="true"]:visible', opts.solo - ).not( tooltip ).length ) { - $( document ).unbind( 'mousemove.' + NAMESPACE ); - trackingBound = FALSE; - } - - // Blur the tooltip - this.blur( event ); - } - - // Define post-animation, state specific properties - after = $.proxy( - function() { - if ( state ) { - // Prevent antialias from disappearing in IE by removing filter - if ( BROWSER.ie ) { - tooltip[0].style.removeAttribute( 'filter' ); - } - - // Remove overflow setting to prevent tip bugs - tooltip.css( 'overflow', '' ); - - // Autofocus elements if enabled - if ( 'string' === typeof opts.autofocus ) { - $( this.options.show.autofocus, tooltip ).focus(); - } - - // If set, hide tooltip when inactive for delay period - this.options.show.target.trigger( 'qtip-' + this.id + '-inactive' ); - } - else { - // Reset CSS states - tooltip.css( - { - display: '', - visibility: '', - opacity: '', - left: '', - top: '' - } - ); - } - - // tooltipvisible/tooltiphidden events - this._trigger( state ? 'visible' : 'hidden' ); - }, this - ); - - // If no effect type is supplied, use a simple toggle - if ( opts.effect === FALSE || animate === FALSE ) { - tooltip[type](); - after(); - } - - // Use custom function if provided - else if ( $.isFunction( opts.effect ) ) { - tooltip.stop( 1, 1 ); - opts.effect.call( tooltip, this ); - tooltip.queue( - 'fx', function( n ) { - after(); - n(); - } - ); - } - - // Use basic fade function by default - else { - tooltip.fadeTo( 90, state ? 1 : 0, after ); - } - - // If inactive hide method is set, active it - if ( state ) { - opts.target.trigger( 'qtip-' + this.id + '-inactive' ); - } - - return this; - }; - - PROTOTYPE.show = function( event ) { - return this.toggle( TRUE, event ); - }; - - PROTOTYPE.hide = function( event ) { - return this.toggle( FALSE, event ); - }; - - ; - PROTOTYPE.focus = function( event ) { - if ( !this.rendered || this.destroyed ) { - return this; - } - - var qtips = $( SELECTOR ), - tooltip = this.tooltip, - curIndex = parseInt( tooltip[0].style.zIndex, 10 ), - newIndex = QTIP.zindex + qtips.length, - focusedElem; - - // Only update the z-index if it has changed and tooltip is not already focused - if ( !tooltip.hasClass( CLASS_FOCUS ) ) { - // tooltipfocus event - if ( this._trigger( 'focus', [newIndex], event ) ) { - // Only update z-index's if they've changed - if ( curIndex !== newIndex ) { - // Reduce our z-index's and keep them properly ordered - qtips.each( - function() { - if ( this.style.zIndex > curIndex ) { - this.style.zIndex = this.style.zIndex - 1; - } - } - ); - - // Fire blur event for focused tooltip - qtips.filter( '.' + CLASS_FOCUS ).qtip( 'blur', event ); - } - - // Set the new z-index - tooltip.addClass( CLASS_FOCUS )[0].style.zIndex = newIndex; - } - } - - return this; - }; - - PROTOTYPE.blur = function( event ) { - if ( !this.rendered || this.destroyed ) { - return this; - } - - // Set focused status to FALSE - this.tooltip.removeClass( CLASS_FOCUS ); - - // tooltipblur event - this._trigger( 'blur', [this.tooltip.css( 'zIndex' )], event ); - - return this; - }; - - ; - PROTOTYPE.disable = function( state ) { - if ( this.destroyed ) { - return this; - } - - // If 'toggle' is passed, toggle the current state - if ( state === 'toggle' ) { - state = !(this.rendered ? this.tooltip.hasClass( CLASS_DISABLED ) : this.disabled); - } - - // Disable if no state passed - else if ( 'boolean' !== typeof state ) { - state = TRUE; - } - - if ( this.rendered ) { - this.tooltip.toggleClass( CLASS_DISABLED, state ) - .attr( 'aria-disabled', state ); - } - - this.disabled = !!state; - - return this; - }; - - PROTOTYPE.enable = function() { - return this.disable( FALSE ); - }; - - ; - PROTOTYPE._createButton = function() { - var self = this, - elements = this.elements, - tooltip = elements.tooltip, - button = this.options.content.button, - isString = typeof button === 'string', - close = isString ? button : 'Close tooltip'; - - if ( elements.button ) { - elements.button.remove(); - } - - // Use custom button if one was supplied by user, else use default - if ( button.jquery ) { - elements.button = button; - } - else { - elements.button = $( - '', { - 'class': 'qtip-close ' + (this.options.style.widget ? '' : NAMESPACE + '-icon'), - 'title': close, - 'aria-label': close - } - ) - .prepend( - $( - '', { - 'class': 'ui-icon ui-icon-close', - 'html': '×' - } - ) - ); - } - - // Create button and setup attributes - elements.button.appendTo( elements.titlebar || tooltip ) - .attr( 'role', 'button' ) - .click( - function( event ) { - if ( !tooltip.hasClass( CLASS_DISABLED ) ) { - self.hide( event ); - } - return FALSE; - } - ); - }; - - PROTOTYPE._updateButton = function( button ) { - // Make sure tooltip is rendered and if not, return - if ( !this.rendered ) { - return FALSE; - } - - var elem = this.elements.button; - if ( button ) { - this._createButton(); - } - else { - elem.remove(); - } - }; - - ;// Widget class creator - function createWidgetClass( cls ) { - return WIDGET.concat( '' ).join( cls ? '-' + cls + ' ' : ' ' ); - } - - // Widget class setter method - PROTOTYPE._setWidget = function() { - var on = this.options.style.widget, - elements = this.elements, - tooltip = elements.tooltip, - disabled = tooltip.hasClass( CLASS_DISABLED ); - - tooltip.removeClass( CLASS_DISABLED ); - CLASS_DISABLED = on ? 'ui-state-disabled' : 'qtip-disabled'; - tooltip.toggleClass( CLASS_DISABLED, disabled ); - - tooltip.toggleClass( 'ui-helper-reset ' + createWidgetClass(), on ).toggleClass( - CLASS_DEFAULT, this.options.style.def && !on - ); - - if ( elements.content ) { - elements.content.toggleClass( createWidgetClass( 'content' ), on ); - } - if ( elements.titlebar ) { - elements.titlebar.toggleClass( createWidgetClass( 'header' ), on ); - } - if ( elements.button ) { - elements.button.toggleClass( NAMESPACE + '-icon', !on ); - } - }; - ; - function cloneEvent( event ) { - return event && { - type: event.type, - pageX: event.pageX, - pageY: event.pageY, - target: event.target, - relatedTarget: event.relatedTarget, - scrollX: event.scrollX || window.pageXOffset || document.body.scrollLeft || document.documentElement.scrollLeft, - scrollY: event.scrollY || window.pageYOffset || document.body.scrollTop || document.documentElement.scrollTop - } || {}; - } - - function delay( callback, duration ) { - // If tooltip has displayed, start hide timer - if ( duration > 0 ) { - return setTimeout( - $.proxy( callback, this ), duration - ); - } - else { - callback.call( this ); - } - } - - function showMethod( event ) { - if ( this.tooltip.hasClass( CLASS_DISABLED ) ) { - return FALSE; - } - - // Clear hide timers - clearTimeout( this.timers.show ); - clearTimeout( this.timers.hide ); - - // Start show timer - this.timers.show = delay.call( - this, - function() { - this.toggle( TRUE, event ); - }, - this.options.show.delay - ); - } - - function hideMethod( event ) { - if ( this.tooltip.hasClass( CLASS_DISABLED ) ) { - return FALSE; - } - - // Check if new target was actually the tooltip element - var relatedTarget = $( event.relatedTarget ), - ontoTooltip = relatedTarget.closest( SELECTOR )[0] === this.tooltip[0], - ontoTarget = relatedTarget[0] === this.options.show.target[0]; - - // Clear timers and stop animation queue - clearTimeout( this.timers.show ); - clearTimeout( this.timers.hide ); - - // Prevent hiding if tooltip is fixed and event target is the tooltip. - // Or if mouse positioning is enabled and cursor momentarily overlaps - if ( this !== relatedTarget[0] && - (this.options.position.target === 'mouse' && ontoTooltip) || - (this.options.hide.fixed && ( - (/mouse(out|leave|move)/).test( event.type ) && (ontoTooltip || ontoTarget)) - ) ) { - try { - event.preventDefault(); - event.stopImmediatePropagation(); - } catch ( e ) { - } - - return; - } - - // If tooltip has displayed, start hide timer - this.timers.hide = delay.call( - this, - function() { - this.toggle( FALSE, event ); - }, - this.options.hide.delay, - this - ); - } - - function inactiveMethod( event ) { - if ( this.tooltip.hasClass( CLASS_DISABLED ) || !this.options.hide.inactive ) { - return FALSE; - } - - // Clear timer - clearTimeout( this.timers.inactive ); - - this.timers.inactive = delay.call( - this, - function() { - this.hide( event ); - }, - this.options.hide.inactive - ); - } - - function repositionMethod( event ) { - if ( this.rendered && this.tooltip[0].offsetWidth > 0 ) { - this.reposition( event ); - } - } - - // Store mouse coordinates - PROTOTYPE._storeMouse = function( event ) { - (this.mouse = cloneEvent( event )).type = 'mousemove'; - }; - - // Bind events - PROTOTYPE._bind = function( targets, events, method, suffix, context ) { - var ns = '.' + this._id + (suffix ? '-' + suffix : ''); - events.length && $( targets ).bind( - (events.split ? events : events.join( ns + ' ' )) + ns, - $.proxy( method, context || this ) - ); - }; - PROTOTYPE._unbind = function( targets, suffix ) { - $( targets ).unbind( '.' + this._id + (suffix ? '-' + suffix : '') ); - }; - - // Apply common event handlers using delegate (avoids excessive .bind calls!) - var ns = '.' + NAMESPACE; - - function delegate( selector, events, method ) { - $( document.body ).delegate( - selector, - (events.split ? events : events.join( ns + ' ' )) + ns, - function() { - var api = QTIP.api[$.attr( this, ATTR_ID )]; - api && !api.disabled && method.apply( api, arguments ); - } - ); - } - - $( - function() { - delegate( - SELECTOR, ['mouseenter', 'mouseleave'], function( event ) { - var state = event.type === 'mouseenter', - tooltip = $( event.currentTarget ), - target = $( event.relatedTarget || event.target ), - options = this.options; - - // On mouseenter... - if ( state ) { - // Focus the tooltip on mouseenter (z-index stacking) - this.focus( event ); - - // Clear hide timer on tooltip hover to prevent it from closing - tooltip.hasClass( CLASS_FIXED ) && !tooltip.hasClass( CLASS_DISABLED ) && clearTimeout( this.timers.hide ); - } - - // On mouseleave... - else { - // Hide when we leave the tooltip and not onto the show target (if a hide event is set) - if ( options.position.target === 'mouse' && options.hide.event && - options.show.target && !target.closest( options.show.target[0] ).length ) { - this.hide( event ); - } - } - - // Add hover class - tooltip.toggleClass( CLASS_HOVER, state ); - } - ); - - // Define events which reset the 'inactive' event handler - delegate( '[' + ATTR_ID + ']', INACTIVE_EVENTS, inactiveMethod ); - } - ); - - // Event trigger - PROTOTYPE._trigger = function( type, args, event ) { - var callback = $.Event( 'tooltip' + type ); - callback.originalEvent = (event && $.extend( {}, event )) || this.cache.event || NULL; - - this.triggering = type; - this.tooltip.trigger( callback, [this].concat( args || [] ) ); - this.triggering = FALSE; - - return !callback.isDefaultPrevented(); - }; - - PROTOTYPE._bindEvents = function( showEvents, hideEvents, showTarget, hideTarget, showMethod, hideMethod ) { - // If hide and show targets are the same... - if ( hideTarget.add( showTarget ).length === hideTarget.length ) { - var toggleEvents = []; - - // Filter identical show/hide events - hideEvents = $.map( - hideEvents, function( type ) { - var showIndex = $.inArray( type, showEvents ); - - // Both events are identical, remove from both hide and show events - // and append to toggleEvents - if ( showIndex > -1 ) { - toggleEvents.push( showEvents.splice( showIndex, 1 )[0] ); - return; - } - - return type; - } - ); - - // Toggle events are special case of identical show/hide events, which happen in sequence - toggleEvents.length && this._bind( - showTarget, toggleEvents, function( event ) { - var state = this.rendered ? this.tooltip[0].offsetWidth > 0 : false; - (state ? hideMethod : showMethod).call( this, event ); - } - ); - } - - // Apply show/hide/toggle events - this._bind( showTarget, showEvents, showMethod ); - this._bind( hideTarget, hideEvents, hideMethod ); - }; - - PROTOTYPE._assignInitialEvents = function( event ) { - var options = this.options, - showTarget = options.show.target, - hideTarget = options.hide.target, - showEvents = options.show.event ? $.trim( '' + options.show.event ).split( ' ' ) : [], - hideEvents = options.hide.event ? $.trim( '' + options.hide.event ).split( ' ' ) : []; - - /* - * Make sure hoverIntent functions properly by using mouseleave as a hide event if - * mouseenter/mouseout is used for show.event, even if it isn't in the users options. - */ - if ( /mouse(over|enter)/i.test( options.show.event ) && !/mouse(out|leave)/i.test( options.hide.event ) ) { - hideEvents.push( 'mouseleave' ); - } - - /* - * Also make sure initial mouse targetting works correctly by caching mousemove coords - * on show targets before the tooltip has rendered. Also set onTarget when triggered to - * keep mouse tracking working. - */ - this._bind( - showTarget, 'mousemove', function( event ) { - this._storeMouse( event ); - this.cache.onTarget = TRUE; - } - ); - - // Define hoverIntent function - function hoverIntent( event ) { - // Only continue if tooltip isn't disabled - if ( this.disabled || this.destroyed ) { - return FALSE; - } - - // Cache the event data - this.cache.event = cloneEvent( event ); - this.cache.target = event ? $( event.target ) : [undefined]; - - // Start the event sequence - clearTimeout( this.timers.show ); - this.timers.show = delay.call( - this, - function() { - this.render( typeof event === 'object' || options.show.ready ); - }, - options.show.delay - ); - } - - // Filter and bind events - this._bindEvents( - showEvents, hideEvents, showTarget, hideTarget, hoverIntent, function() { - clearTimeout( this.timers.show ); - } - ); - - // Prerendering is enabled, create tooltip now - if ( options.show.ready || options.prerender ) { - hoverIntent.call( this, event ); - } - }; - - // Event assignment method - PROTOTYPE._assignEvents = function() { - var self = this, - options = this.options, - posOptions = options.position, - - tooltip = this.tooltip, - showTarget = options.show.target, - hideTarget = options.hide.target, - containerTarget = posOptions.container, - viewportTarget = posOptions.viewport, - documentTarget = $( document ), - bodyTarget = $( document.body ), - windowTarget = $( window ), - - showEvents = options.show.event ? $.trim( '' + options.show.event ).split( ' ' ) : [], - hideEvents = options.hide.event ? $.trim( '' + options.hide.event ).split( ' ' ) : []; - - - // Assign passed event callbacks - $.each( - options.events, function( name, callback ) { - self._bind( - tooltip, name === 'toggle' ? ['tooltipshow', 'tooltiphide'] : ['tooltip' + name], - callback, null, tooltip - ); - } - ); - - // Hide tooltips when leaving current window/frame (but not select/option elements) - if ( /mouse(out|leave)/i.test( options.hide.event ) && options.hide.leave === 'window' ) { - this._bind( - documentTarget, ['mouseout', 'blur'], function( event ) { - if ( !/select|option/.test( event.target.nodeName ) && !event.relatedTarget ) { - this.hide( event ); - } - } - ); - } - - // Enable hide.fixed by adding appropriate class - if ( options.hide.fixed ) { - hideTarget = hideTarget.add( tooltip.addClass( CLASS_FIXED ) ); - } - - /* - * Make sure hoverIntent functions properly by using mouseleave to clear show timer if - * mouseenter/mouseout is used for show.event, even if it isn't in the users options. - */ - else if ( /mouse(over|enter)/i.test( options.show.event ) ) { - this._bind( - hideTarget, 'mouseleave', function() { - clearTimeout( this.timers.show ); - } - ); - } - - // Hide tooltip on document mousedown if unfocus events are enabled - if ( ('' + options.hide.event).indexOf( 'unfocus' ) > -1 ) { - this._bind( - containerTarget.closest( 'html' ), ['mousedown', 'touchstart'], function( event ) { - var elem = $( event.target ), - enabled = this.rendered && !this.tooltip.hasClass( CLASS_DISABLED ) && this.tooltip[0].offsetWidth > 0, - isAncestor = elem.parents( SELECTOR ).filter( this.tooltip[0] ).length > 0; - - if ( elem[0] !== this.target[0] && elem[0] !== this.tooltip[0] && !isAncestor && !this.target.has( elem[0] ).length && enabled - ) { - this.hide( event ); - } - } - ); - } - - // Check if the tooltip hides when inactive - if ( 'number' === typeof options.hide.inactive ) { - // Bind inactive method to show target(s) as a custom event - this._bind( showTarget, 'qtip-' + this.id + '-inactive', inactiveMethod ); - - // Define events which reset the 'inactive' event handler - this._bind( hideTarget.add( tooltip ), QTIP.inactiveEvents, inactiveMethod, '-inactive' ); - } - - // Filter and bind events - this._bindEvents( showEvents, hideEvents, showTarget, hideTarget, showMethod, hideMethod ); - - // Mouse movement bindings - this._bind( - showTarget.add( tooltip ), 'mousemove', function( event ) { - // Check if the tooltip hides when mouse is moved a certain distance - if ( 'number' === typeof options.hide.distance ) { - var origin = this.cache.origin || {}, - limit = this.options.hide.distance, - abs = Math.abs; - - // Check if the movement has gone beyond the limit, and hide it if so - if ( abs( event.pageX - origin.pageX ) >= limit || abs( event.pageY - origin.pageY ) >= limit ) { - this.hide( event ); - } - } - - // Cache mousemove coords on show targets - this._storeMouse( event ); - } - ); - - // Mouse positioning events - if ( posOptions.target === 'mouse' ) { - // If mouse adjustment is on... - if ( posOptions.adjust.mouse ) { - // Apply a mouseleave event so we don't get problems with overlapping - if ( options.hide.event ) { - // Track if we're on the target or not - this._bind( - showTarget, ['mouseenter', 'mouseleave'], function( event ) { - this.cache.onTarget = event.type === 'mouseenter'; - } - ); - } - - // Update tooltip position on mousemove - this._bind( - documentTarget, 'mousemove', function( event ) { - // Update the tooltip position only if the tooltip is visible and adjustment is enabled - if ( this.rendered && this.cache.onTarget && !this.tooltip.hasClass( CLASS_DISABLED ) && this.tooltip[0].offsetWidth > 0 ) { - this.reposition( event ); - } - } - ); - } - } - - // Adjust positions of the tooltip on window resize if enabled - if ( posOptions.adjust.resize || viewportTarget.length ) { - this._bind( - $.event.special.resize ? viewportTarget : windowTarget, 'resize', repositionMethod - ); - } - - // Adjust tooltip position on scroll of the window or viewport element if present - if ( posOptions.adjust.scroll ) { - this._bind( windowTarget.add( posOptions.container ), 'scroll', repositionMethod ); - } - }; - - // Un-assignment method - PROTOTYPE._unassignEvents = function() { - var targets = [ - this.options.show.target[0], - this.options.hide.target[0], - this.rendered && this.tooltip[0], - this.options.position.container[0], - this.options.position.viewport[0], - this.options.position.container.closest( 'html' )[0], // unfocus - window, - document - ]; - - this._unbind( - $( [] ).pushStack( - $.grep( - targets, function( i ) { - return typeof i === 'object'; - } - ) - ) - ); - }; - - ;// Initialization method - function init( elem, id, opts ) { - var obj, posOptions, attr, config, title, - - // Setup element references - docBody = $( document.body ), - - // Use document body instead of document element if needed - newTarget = elem[0] === document ? docBody : elem, - - // Grab metadata from element if plugin is present - metadata = (elem.metadata) ? elem.metadata( opts.metadata ) : NULL, - - // If metadata type if HTML5, grab 'name' from the object instead, or use the regular data object otherwise - metadata5 = opts.metadata.type === 'html5' && metadata ? metadata[opts.metadata.name] : NULL, - - // Grab data from metadata.name (or data-qtipopts as fallback) using .data() method, - html5 = elem.data( opts.metadata.name || 'qtipopts' ); - - // If we don't get an object returned attempt to parse it manualyl without parseJSON - try { - html5 = typeof html5 === 'string' ? $.parseJSON( html5 ) : html5; - } catch ( e ) { - } - - // Merge in and sanitize metadata - config = $.extend( - TRUE, {}, QTIP.defaults, opts, - typeof html5 === 'object' ? sanitizeOptions( html5 ) : NULL, - sanitizeOptions( metadata5 || metadata ) - ); - - // Re-grab our positioning options now we've merged our metadata and set id to passed value - posOptions = config.position; - config.id = id; - - // Setup missing content if none is detected - if ( 'boolean' === typeof config.content.text ) { - attr = elem.attr( config.content.attr ); - - // Grab from supplied attribute if available - if ( config.content.attr !== FALSE && attr ) { - config.content.text = attr; - } - - // No valid content was found, abort render - else { - return FALSE; - } - } - - // Setup target options - if ( !posOptions.container.length ) { - posOptions.container = docBody; - } - if ( posOptions.target === FALSE ) { - posOptions.target = newTarget; - } - if ( config.show.target === FALSE ) { - config.show.target = newTarget; - } - if ( config.show.solo === TRUE ) { - config.show.solo = posOptions.container.closest( 'body' ); - } - if ( config.hide.target === FALSE ) { - config.hide.target = newTarget; - } - if ( config.position.viewport === TRUE ) { - config.position.viewport = posOptions.container; - } - - // Ensure we only use a single container - posOptions.container = posOptions.container.eq( 0 ); - - // Convert position corner values into x and y strings - posOptions.at = new CORNER( posOptions.at, TRUE ); - posOptions.my = new CORNER( posOptions.my ); - - // Destroy previous tooltip if overwrite is enabled, or skip element if not - if ( elem.data( NAMESPACE ) ) { - if ( config.overwrite ) { - elem.qtip( 'destroy', true ); - } - else if ( config.overwrite === FALSE ) { - return FALSE; - } - } - - // Add has-qtip attribute - elem.attr( ATTR_HAS, id ); - - // Remove title attribute and store it if present - if ( config.suppress && (title = elem.attr( 'title' )) ) { - // Final attr call fixes event delegatiom and IE default tooltip showing problem - elem.removeAttr( 'title' ).attr( oldtitle, title ).attr( 'title', '' ); - } - - // Initialize the tooltip and add API reference - obj = new QTip( elem, config, id, !!attr ); - elem.data( NAMESPACE, obj ); - - // Catch remove/removeqtip events on target element to destroy redundant tooltip - elem.one( - 'remove.qtip-' + id + ' removeqtip.qtip-' + id, function() { - var api; - if ( (api = $( this ).data( NAMESPACE )) ) { - api.destroy( true ); - } - } - ); - - return obj; - } - - // jQuery $.fn extension method - QTIP = $.fn.qtip = function( options, notation, newValue ) { - var command = ('' + options).toLowerCase(), // Parse command - returned = NULL, - args = $.makeArray( arguments ).slice( 1 ), - event = args[args.length - 1], - opts = this[0] ? $.data( this[0], NAMESPACE ) : NULL; - - // Check for API request - if ( (!arguments.length && opts) || command === 'api' ) { - return opts; - } - - // Execute API command if present - else if ( 'string' === typeof options ) { - this.each( - function() { - var api = $.data( this, NAMESPACE ); - if ( !api ) { - return TRUE; - } - - // Cache the event if possible - if ( event && event.timeStamp ) { - api.cache.event = event; - } - - // Check for specific API commands - if ( notation && (command === 'option' || command === 'options') ) { - if ( newValue !== undefined || $.isPlainObject( notation ) ) { - api.set( notation, newValue ); - } - else { - returned = api.get( notation ); - return FALSE; - } - } - - // Execute API command - else if ( api[command] ) { - api[command].apply( api, args ); - } - } - ); - - return returned !== NULL ? returned : this; - } - - // No API commands. validate provided options and setup qTips - else if ( 'object' === typeof options || !arguments.length ) { - // Sanitize options first - opts = sanitizeOptions( $.extend( TRUE, {}, options ) ); - - return this.each( - function( i ) { - var api, id; - - // Find next available ID, or use custom ID if provided - id = $.isArray( opts.id ) ? opts.id[i] : opts.id; - id = !id || id === FALSE || id.length < 1 || QTIP.api[id] ? QTIP.nextid++ : id; - - // Initialize the qTip and re-grab newly sanitized options - api = init( $( this ), id, opts ); - if ( api === FALSE ) { - return TRUE; - } - else { - QTIP.api[id] = api; - } - - // Initialize plugins - $.each( - PLUGINS, function() { - if ( this.initialize === 'initialize' ) { - this( api ); - } - } - ); - - // Assign initial pre-render events - api._assignInitialEvents( event ); - } - ); - } - }; - - // Expose class - $.qtip = QTip; - - // Populated in render method - QTIP.api = {}; - ; - $.each( - { - /* Allow other plugins to successfully retrieve the title of an element with a qTip applied */ - attr: function( attr, val ) { - if ( this.length ) { - var self = this[0], - title = 'title', - api = $.data( self, 'qtip' ); - - if ( attr === title && api && 'object' === typeof api && api.options.suppress ) { - if ( arguments.length < 2 ) { - return $.attr( self, oldtitle ); - } - - // If qTip is rendered and title was originally used as content, update it - if ( api && api.options.content.attr === title && api.cache.attr ) { - api.set( 'content.text', val ); - } - - // Use the regular attr method to set, then cache the result - return this.attr( oldtitle, val ); - } - } - - return $.fn['attr' + replaceSuffix].apply( this, arguments ); - }, - - /* Allow clone to correctly retrieve cached title attributes */ - clone: function( keepData ) { - var titles = $( [] ), title = 'title', - - // Clone our element using the real clone method - elems = $.fn['clone' + replaceSuffix].apply( this, arguments ); - - // Grab all elements with an oldtitle set, and change it to regular title attribute, if keepData is false - if ( !keepData ) { - elems.filter( '[' + oldtitle + ']' ).attr( - 'title', function() { - return $.attr( this, oldtitle ); - } - ) - .removeAttr( oldtitle ); - } - - return elems; - } - }, function( name, func ) { - if ( !func || $.fn[name + replaceSuffix] ) { - return TRUE; - } - - var old = $.fn[name + replaceSuffix] = $.fn[name]; - $.fn[name] = function() { - return func.apply( this, arguments ) || old.apply( this, arguments ); - }; - } - ); - - /* Fire off 'removeqtip' handler in $.cleanData if jQuery UI not present (it already does similar). - * This snippet is taken directly from jQuery UI source code found here: - * http://code.jquery.com/ui/jquery-ui-git.js - */ - if ( !$.ui ) { - $['cleanData' + replaceSuffix] = $.cleanData; - $.cleanData = function( elems ) { - for ( var i = 0, elem; (elem = $( elems[i] )).length; i++ ) { - if ( elem.attr( ATTR_HAS ) ) { - try { - elem.triggerHandler( 'removeqtip' ); - } - catch ( e ) { - } - } - } - $['cleanData' + replaceSuffix].apply( this, arguments ); - }; - } - - ;// qTip version - QTIP.version = '2.2.0'; - - // Base ID for all qTips - QTIP.nextid = 0; - - // Inactive events array - QTIP.inactiveEvents = INACTIVE_EVENTS; - - // Base z-index for all qTips - QTIP.zindex = 15000; - - // Define configuration defaults - QTIP.defaults = { - prerender: FALSE, - id: FALSE, - overwrite: TRUE, - suppress: TRUE, - content: { - text: TRUE, - attr: 'title', - title: FALSE, - button: FALSE - }, - position: { - my: 'top left', - at: 'bottom right', - target: FALSE, - container: FALSE, - viewport: FALSE, - adjust: { - x: 0, y: 0, - mouse: TRUE, - scroll: TRUE, - resize: TRUE, - method: 'flipinvert flipinvert' - }, - effect: function( api, pos, viewport ) { - $( this ).animate( - pos, { - duration: 200, - queue: FALSE - } - ); - } - }, - show: { - target: FALSE, - event: 'mouseenter', - effect: TRUE, - delay: 90, - solo: FALSE, - ready: FALSE, - autofocus: FALSE - }, - hide: { - target: FALSE, - event: 'mouseleave', - effect: TRUE, - delay: 0, - fixed: FALSE, - inactive: FALSE, - leave: 'window', - distance: FALSE - }, - style: { - classes: '', - widget: FALSE, - width: FALSE, - height: FALSE, - def: TRUE - }, - events: { - render: NULL, - move: NULL, - show: NULL, - hide: NULL, - toggle: NULL, - visible: NULL, - hidden: NULL, - focus: NULL, - blur: NULL - } - }; - - ; - var TIP, - - // .bind()/.on() namespace - TIPNS = '.qtip-tip', - - // Common CSS strings - MARGIN = 'margin', - BORDER = 'border', - COLOR = 'color', - BG_COLOR = 'background-color', - TRANSPARENT = 'transparent', - IMPORTANT = ' !important', - - // Check if the browser supports elements - HASCANVAS = !!document.createElement( 'canvas' ).getContext, - - // Invalid colour values used in parseColours() - INVALID = /rgba?\(0, 0, 0(, 0)?\)|transparent|#123456/i; - - // Camel-case method, taken from jQuery source - // http://code.jquery.com/jquery-1.8.0.js - function camel( s ) { - return s.charAt( 0 ).toUpperCase() + s.slice( 1 ); - } - - /* - * Modified from Modernizr's testPropsAll() - * http://modernizr.com/downloads/modernizr-latest.js - */ - var cssProps = {}, cssPrefixes = ["Webkit", "O", "Moz", "ms"]; - - function vendorCss( elem, prop ) { - var ucProp = prop.charAt( 0 ).toUpperCase() + prop.slice( 1 ), - props = (prop + ' ' + cssPrefixes.join( ucProp + ' ' ) + ucProp).split( ' ' ), - cur, val, i = 0; - - // If the property has already been mapped... - if ( cssProps[prop] ) { - return elem.css( cssProps[prop] ); - } - - while ( (cur = props[i++]) ) { - if ( (val = elem.css( cur )) !== undefined ) { - return cssProps[prop] = cur, val; - } - } - } - - // Parse a given elements CSS property into an int - function intCss( elem, prop ) { - return Math.ceil( parseFloat( vendorCss( elem, prop ) ) ); - } - - - // VML creation (for IE only) - if ( !HASCANVAS ) { - var createVML = function( tag, props, style ) { - return ''; - }; - } - - // Canvas only definitions - else { - var PIXEL_RATIO = window.devicePixelRatio || 1, - BACKING_STORE_RATIO = (function() { - var context = document.createElement( 'canvas' ).getContext( '2d' ); - return context.backingStorePixelRatio || context.webkitBackingStorePixelRatio || context.mozBackingStorePixelRatio || - context.msBackingStorePixelRatio || context.oBackingStorePixelRatio || 1; - }()), - SCALE = PIXEL_RATIO / BACKING_STORE_RATIO; - } - - - function Tip( qtip, options ) { - this._ns = 'tip'; - this.options = options; - this.offset = options.offset; - this.size = [options.width, options.height]; - - // Initialize - this.init( (this.qtip = qtip) ); - } - - $.extend( - Tip.prototype, { - init: function( qtip ) { - var context, tip; - - // Create tip element and prepend to the tooltip - tip = this.element = qtip.elements.tip = $( - '
    ', {'class': NAMESPACE + '-tip'} - ).prependTo( qtip.tooltip ); - - // Create tip drawing element(s) - if ( HASCANVAS ) { - // save() as soon as we create the canvas element so FF2 doesn't bork on our first restore()! - context = $( '' ).appendTo( this.element )[0].getContext( '2d' ); - - // Setup constant parameters - context.lineJoin = 'miter'; - context.miterLimit = 100000; - context.save(); - } - else { - context = createVML( 'shape', 'coordorigin="0,0"', 'position:absolute;' ); - this.element.html( context + context ); - - // Prevent mousing down on the tip since it causes problems with .live() handling in IE due to VML - qtip._bind( - $( '*', tip ).add( tip ), ['click', 'mousedown'], function( event ) { - event.stopPropagation(); - }, this._ns - ); - } - - // Bind update events - qtip._bind( qtip.tooltip, 'tooltipmove', this.reposition, this._ns, this ); - - // Create it - this.create(); - }, - - _swapDimensions: function() { - this.size[0] = this.options.height; - this.size[1] = this.options.width; - }, - _resetDimensions: function() { - this.size[0] = this.options.width; - this.size[1] = this.options.height; - }, - - _useTitle: function( corner ) { - var titlebar = this.qtip.elements.titlebar; - return titlebar && ( - corner.y === TOP || (corner.y === CENTER && this.element.position().top + (this.size[1] / 2) + this.options.offset < titlebar.outerHeight( TRUE )) - ); - }, - - _parseCorner: function( corner ) { - var my = this.qtip.options.position.my; - - // Detect corner and mimic properties - if ( corner === FALSE || my === FALSE ) { - corner = FALSE; - } - else if ( corner === TRUE ) { - corner = new CORNER( my.string() ); - } - else if ( !corner.string ) { - corner = new CORNER( corner ); - corner.fixed = TRUE; - } - - return corner; - }, - - _parseWidth: function( corner, side, use ) { - var elements = this.qtip.elements, - prop = BORDER + camel( side ) + 'Width'; - - return (use ? intCss( use, prop ) : ( - intCss( elements.content, prop ) || - intCss( this._useTitle( corner ) && elements.titlebar || elements.content, prop ) || - intCss( elements.tooltip, prop ) - )) || 0; - }, - - _parseRadius: function( corner ) { - var elements = this.qtip.elements, - prop = BORDER + camel( corner.y ) + camel( corner.x ) + 'Radius'; - - return BROWSER.ie < 9 ? 0 : - intCss( this._useTitle( corner ) && elements.titlebar || elements.content, prop ) || - intCss( elements.tooltip, prop ) || 0; - }, - - _invalidColour: function( elem, prop, compare ) { - var val = elem.css( prop ); - return !val || (compare && val === elem.css( compare )) || INVALID.test( val ) ? FALSE : val; - }, - - _parseColours: function( corner ) { - var elements = this.qtip.elements, - tip = this.element.css( 'cssText', '' ), - borderSide = BORDER + camel( corner[corner.precedance] ) + camel( COLOR ), - colorElem = this._useTitle( corner ) && elements.titlebar || elements.content, - css = this._invalidColour, color = []; - - // Attempt to detect the background colour from various elements, left-to-right precedance - color[0] = css( tip, BG_COLOR ) || css( colorElem, BG_COLOR ) || css( - elements.content, BG_COLOR - ) || - css( elements.tooltip, BG_COLOR ) || tip.css( BG_COLOR ); - - // Attempt to detect the correct border side colour from various elements, left-to-right precedance - color[1] = css( tip, borderSide, COLOR ) || css( colorElem, borderSide, COLOR ) || - css( elements.content, borderSide, COLOR ) || css( - elements.tooltip, borderSide, COLOR - ) || elements.tooltip.css( borderSide ); - - // Reset background and border colours - $( '*', tip ).add( tip ).css( - 'cssText', - BG_COLOR + ':' + TRANSPARENT + IMPORTANT + ';' + BORDER + ':0' + IMPORTANT + ';' - ); - - return color; - }, - - _calculateSize: function( corner ) { - var y = corner.precedance === Y, - width = this.options['width'], - height = this.options['height'], - isCenter = corner.abbrev() === 'c', - base = (y ? width : height) * (isCenter ? 0.5 : 1), - pow = Math.pow, - round = Math.round, - bigHyp, ratio, result, - - smallHyp = Math.sqrt( pow( base, 2 ) + pow( height, 2 ) ), - hyp = [(this.border / base) * smallHyp, (this.border / height) * smallHyp]; - - hyp[2] = Math.sqrt( pow( hyp[0], 2 ) - pow( this.border, 2 ) ); - hyp[3] = Math.sqrt( pow( hyp[1], 2 ) - pow( this.border, 2 ) ); - - bigHyp = smallHyp + hyp[2] + hyp[3] + (isCenter ? 0 : hyp[0]); - ratio = bigHyp / smallHyp; - - result = [round( ratio * width ), round( ratio * height )]; - return y ? result : result.reverse(); - }, - - // Tip coordinates calculator - _calculateTip: function( corner, size, scale ) { - scale = scale || 1; - size = size || this.size; - - var width = size[0] * scale, - height = size[1] * scale, - width2 = Math.ceil( width / 2 ), height2 = Math.ceil( height / 2 ), - - // Define tip coordinates in terms of height and width values - tips = { - br: [0, 0, width, height, width, 0], - bl: [0, 0, width, 0, 0, height], - tr: [0, height, width, 0, width, height], - tl: [0, 0, 0, height, width, height], - tc: [0, height, width2, 0, width, height], - bc: [0, 0, width, 0, width2, height], - rc: [0, 0, width, height2, 0, height], - lc: [width, 0, width, height, 0, height2] - }; - - // Set common side shapes - tips.lt = tips.br; - tips.rt = tips.bl; - tips.lb = tips.tr; - tips.rb = tips.tl; - - return tips[corner.abbrev()]; - }, - - // Tip coordinates drawer (canvas) - _drawCoords: function( context, coords ) { - context.beginPath(); - context.moveTo( coords[0], coords[1] ); - context.lineTo( coords[2], coords[3] ); - context.lineTo( coords[4], coords[5] ); - context.closePath(); - }, - - create: function() { - // Determine tip corner - var c = this.corner = (HASCANVAS || BROWSER.ie) && this._parseCorner( this.options.corner ); - - // If we have a tip corner... - if ( (this.enabled = !!this.corner && this.corner.abbrev() !== 'c') ) { - // Cache it - this.qtip.cache.corner = c.clone(); - - // Create it - this.update(); - } - - // Toggle tip element - this.element.toggle( this.enabled ); - - return this.corner; - }, - - update: function( corner, position ) { - if ( !this.enabled ) { - return this; - } - - var elements = this.qtip.elements, - tip = this.element, - inner = tip.children(), - options = this.options, - curSize = this.size, - mimic = options.mimic, - round = Math.round, - color, precedance, context, - coords, bigCoords, translate, newSize, border, BACKING_STORE_RATIO; - - // Re-determine tip if not already set - if ( !corner ) { - corner = this.qtip.cache.corner || this.corner; - } - - // Use corner property if we detect an invalid mimic value - if ( mimic === FALSE ) { - mimic = corner; - } - - // Otherwise inherit mimic properties from the corner object as necessary - else { - mimic = new CORNER( mimic ); - mimic.precedance = corner.precedance; - - if ( mimic.x === 'inherit' ) { - mimic.x = corner.x; - } - else if ( mimic.y === 'inherit' ) { - mimic.y = corner.y; - } - else if ( mimic.x === mimic.y ) { - mimic[corner.precedance] = corner[corner.precedance]; - } - } - precedance = mimic.precedance; - - // Ensure the tip width.height are relative to the tip position - if ( corner.precedance === X ) { - this._swapDimensions(); - } - else { - this._resetDimensions(); - } - - // Update our colours - color = this.color = this._parseColours( corner ); - - // Detect border width, taking into account colours - if ( color[1] !== TRANSPARENT ) { - // Grab border width - border = this.border = this._parseWidth( corner, corner[corner.precedance] ); - - // If border width isn't zero, use border color as fill if it's not invalid (1.0 style tips) - if ( options.border && border < 1 && !INVALID.test( color[1] ) ) { - color[0] = color[1]; - } - - // Set border width (use detected border width if options.border is true) - this.border = border = options.border !== TRUE ? options.border : border; - } - - // Border colour was invalid, set border to zero - else { - this.border = border = 0; - } - - // Determine tip size - newSize = this.size = this._calculateSize( corner ); - tip.css( - { - width: newSize[0], - height: newSize[1], - lineHeight: newSize[1] + 'px' - } - ); - - // Calculate tip translation - if ( corner.precedance === Y ) { - translate = [ - round( mimic.x === LEFT ? border : mimic.x === RIGHT ? newSize[0] - curSize[0] - border : (newSize[0] - curSize[0]) / 2 ), - round( mimic.y === TOP ? newSize[1] - curSize[1] : 0 ) - ]; - } - else { - translate = [ - round( mimic.x === LEFT ? newSize[0] - curSize[0] : 0 ), - round( mimic.y === TOP ? border : mimic.y === BOTTOM ? newSize[1] - curSize[1] - border : (newSize[1] - curSize[1]) / 2 ) - ]; - } - - // Canvas drawing implementation - if ( HASCANVAS ) { - // Grab canvas context and clear/save it - context = inner[0].getContext( '2d' ); - context.restore(); - context.save(); - context.clearRect( 0, 0, 6000, 6000 ); - - // Calculate coordinates - coords = this._calculateTip( mimic, curSize, SCALE ); - bigCoords = this._calculateTip( mimic, this.size, SCALE ); - - // Set the canvas size using calculated size - inner.attr( WIDTH, newSize[0] * SCALE ).attr( HEIGHT, newSize[1] * SCALE ); - inner.css( WIDTH, newSize[0] ).css( HEIGHT, newSize[1] ); - - // Draw the outer-stroke tip - this._drawCoords( context, bigCoords ); - context.fillStyle = color[1]; - context.fill(); - - // Draw the actual tip - context.translate( translate[0] * SCALE, translate[1] * SCALE ); - this._drawCoords( context, coords ); - context.fillStyle = color[0]; - context.fill(); - } - - // VML (IE Proprietary implementation) - else { - // Calculate coordinates - coords = this._calculateTip( mimic ); - - // Setup coordinates string - coords = 'm' + coords[0] + ',' + coords[1] + ' l' + coords[2] + - ',' + coords[3] + ' ' + coords[4] + ',' + coords[5] + ' xe'; - - // Setup VML-specific offset for pixel-perfection - translate[2] = border && /^(r|b)/i.test( corner.string() ) ? - BROWSER.ie === 8 ? 2 : 1 : 0; - - // Set initial CSS - inner.css( - { - coordsize: (newSize[0] + border) + ' ' + (newSize[1] + border), - antialias: '' + (mimic.string().indexOf( CENTER ) > -1), - left: translate[0] - (translate[2] * Number( precedance === X )), - top: translate[1] - (translate[2] * Number( precedance === Y )), - width: newSize[0] + border, - height: newSize[1] + border - } - ) - .each( - function( i ) { - var $this = $( this ); - - // Set shape specific attributes - $this[$this.prop ? 'prop' : 'attr']( - { - coordsize: (newSize[0] + border) + ' ' + (newSize[1] + border), - path: coords, - fillcolor: color[0], - filled: !!i, - stroked: !i - } - ) - .toggle( !!(border || i) ); - - // Check if border is enabled and add stroke element - !i && $this.html( - createVML( - 'stroke', - 'weight="' + (border * 2) + 'px" color="' + color[1] + '" miterlimit="1000" joinstyle="miter"' - ) - ); - } - ); - } - - // Opera bug #357 - Incorrect tip position - // https://github.com/Craga89/qTip2/issues/367 - window.opera && setTimeout( - function() { - elements.tip.css( - { - display: 'inline-block', - visibility: 'visible' - } - ); - }, 1 - ); - - // Position if needed - if ( position !== FALSE ) { - this.calculate( corner, newSize ); - } - }, - - calculate: function( corner, size ) { - if ( !this.enabled ) { - return FALSE; - } - - var self = this, - elements = this.qtip.elements, - tip = this.element, - userOffset = this.options.offset, - isWidget = elements.tooltip.hasClass( 'ui-widget' ), - position = {}, - precedance, corners; - - // Inherit corner if not provided - corner = corner || this.corner; - precedance = corner.precedance; - - // Determine which tip dimension to use for adjustment - size = size || this._calculateSize( corner ); - - // Setup corners and offset array - corners = [corner.x, corner.y]; - if ( precedance === X ) { - corners.reverse(); - } - - // Calculate tip position - $.each( - corners, function( i, side ) { - var b, bc, br; - - if ( side === CENTER ) { - b = precedance === Y ? LEFT : TOP; - position[b] = '50%'; - position[MARGIN + '-' + b] = -Math.round( size[precedance === Y ? 0 : 1] / 2 ) + userOffset; - } - else { - b = self._parseWidth( corner, side, elements.tooltip ); - bc = self._parseWidth( corner, side, elements.content ); - br = self._parseRadius( corner ); - - position[side] = Math.max( - -self.border, i ? bc : (userOffset + (br > b ? br : -b)) - ); - } - } - ); - - // Adjust for tip size - position[corner[precedance]] -= size[precedance === X ? 0 : 1]; - - // Set and return new position - tip.css( {margin: '', top: '', bottom: '', left: '', right: ''} ).css( position ); - return position; - }, - - reposition: function( event, api, pos, viewport ) { - if ( !this.enabled ) { - return; - } - - var cache = api.cache, - newCorner = this.corner.clone(), - adjust = pos.adjusted, - method = api.options.position.adjust.method.split( ' ' ), - horizontal = method[0], - vertical = method[1] || method[0], - shift = {left: FALSE, top: FALSE, x: 0, y: 0}, - offset, css = {}, props; - - function shiftflip( direction, precedance, popposite, side, opposite ) { - // Horizontal - Shift or flip method - if ( direction === SHIFT && newCorner.precedance === precedance && adjust[side] && newCorner[popposite] !== CENTER ) { - newCorner.precedance = newCorner.precedance === X ? Y : X; - } - else if ( direction !== SHIFT && adjust[side] ) { - newCorner[precedance] = newCorner[precedance] === CENTER ? - (adjust[side] > 0 ? side : opposite) : (newCorner[precedance] === side ? opposite : side); - } - } - - function shiftonly( xy, side, opposite ) { - if ( newCorner[xy] === CENTER ) { - css[MARGIN + '-' + side] = shift[xy] = offset[MARGIN + '-' + side] - adjust[side]; - } - else { - props = offset[opposite] !== undefined ? - [adjust[side], -offset[side]] : [-adjust[side], offset[side]]; - - if ( (shift[xy] = Math.max( props[0], props[1] )) > props[0] ) { - pos[side] -= adjust[side]; - shift[side] = FALSE; - } - - css[offset[opposite] !== undefined ? opposite : side] = shift[xy]; - } - } - - // If our tip position isn't fixed e.g. doesn't adjust with viewport... - if ( this.corner.fixed !== TRUE ) { - // Perform shift/flip adjustments - shiftflip( horizontal, X, Y, LEFT, RIGHT ); - shiftflip( vertical, Y, X, TOP, BOTTOM ); - - // Update and redraw the tip if needed (check cached details of last drawn tip) - if ( newCorner.string() !== cache.corner.string() && (cache.cornerTop !== adjust.top || cache.cornerLeft !== adjust.left) ) { - this.update( newCorner, FALSE ); - } - } - - // Setup tip offset properties - offset = this.calculate( newCorner ); - - // Readjust offset object to make it left/top - if ( offset.right !== undefined ) { - offset.left = -offset.right; - } - if ( offset.bottom !== undefined ) { - offset.top = -offset.bottom; - } - offset.user = this.offset; - - // Perform shift adjustments - if ( shift.left = (horizontal === SHIFT && !!adjust.left) ) { - shiftonly( X, LEFT, RIGHT ); - } - if ( shift.top = (vertical === SHIFT && !!adjust.top) ) { - shiftonly( Y, TOP, BOTTOM ); - } - - /* - * If the tip is adjusted in both dimensions, or in a - * direction that would cause it to be anywhere but the - * outer border, hide it! - */ - this.element.css( css ).toggle( - !((shift.x && shift.y) || (newCorner.x === CENTER && shift.y) || (newCorner.y === CENTER && shift.x)) - ); - - // Adjust position to accomodate tip dimensions - pos.left -= offset.left.charAt ? offset.user : - horizontal !== SHIFT || shift.top || !shift.left && !shift.top ? offset.left + this.border : 0; - pos.top -= offset.top.charAt ? offset.user : - vertical !== SHIFT || shift.left || !shift.left && !shift.top ? offset.top + this.border : 0; - - // Cache details - cache.cornerLeft = adjust.left; - cache.cornerTop = adjust.top; - cache.corner = newCorner.clone(); - }, - - destroy: function() { - // Unbind events - this.qtip._unbind( this.qtip.tooltip, this._ns ); - - // Remove the tip element(s) - if ( this.qtip.elements.tip ) { - this.qtip.elements.tip.find( '*' ) - .remove().end().remove(); - } - } - } - ); - - TIP = PLUGINS.tip = function( api ) { - return new Tip( api, api.options.style.tip ); - }; - - // Initialize tip on render - TIP.initialize = 'render'; - - // Setup plugin sanitization options - TIP.sanitize = function( options ) { - if ( options.style && 'tip' in options.style ) { - var opts = options.style.tip; - if ( typeof opts !== 'object' ) { - opts = options.style.tip = {corner: opts}; - } - if ( !(/string|boolean/i).test( typeof opts.corner ) ) { - opts.corner = TRUE; - } - } - }; - - // Add new option checks for the plugin - CHECKS.tip = { - '^position.my|style.tip.(corner|mimic|border)$': function() { - // Make sure a tip can be drawn - this.create(); - - // Reposition the tooltip - this.qtip.reposition(); - }, - '^style.tip.(height|width)$': function( obj ) { - // Re-set dimensions and redraw the tip - this.size = [obj.width, obj.height]; - this.update(); - - // Reposition the tooltip - this.qtip.reposition(); - }, - '^content.title|style.(classes|widget)$': function() { - this.update(); - } - }; - - // Extend original qTip defaults - $.extend( - TRUE, QTIP.defaults, { - style: { - tip: { - corner: TRUE, - mimic: FALSE, - width: 6, - height: 6, - border: TRUE, - offset: 0 - } - } - } - ); - - ; - var MODAL, OVERLAY, - MODALCLASS = 'qtip-modal', - MODALSELECTOR = '.' + MODALCLASS; - - OVERLAY = function() { - var self = this, - focusableElems = {}, - current, onLast, - prevState, elem; - - // Modified code from jQuery UI 1.10.0 source - // http://code.jquery.com/ui/1.10.0/jquery-ui.js - function focusable( element ) { - // Use the defined focusable checker when possible - if ( $.expr[':'].focusable ) { - return $.expr[':'].focusable; - } - - var isTabIndexNotNaN = !isNaN( $.attr( element, 'tabindex' ) ), - nodeName = element.nodeName && element.nodeName.toLowerCase(), - map, mapName, img; - - if ( 'area' === nodeName ) { - map = element.parentNode; - mapName = map.name; - if ( !element.href || !mapName || map.nodeName.toLowerCase() !== 'map' ) { - return false; - } - img = $( 'img[usemap=#' + mapName + ']' )[0]; - return !!img && img.is( ':visible' ); - } - return (/input|select|textarea|button|object/.test( nodeName ) ? - !element.disabled : - 'a' === nodeName ? - element.href || isTabIndexNotNaN : - isTabIndexNotNaN - ); - } - - // Focus inputs using cached focusable elements (see update()) - function focusInputs( blurElems ) { - // Blurring body element in IE causes window.open windows to unfocus! - if ( focusableElems.length < 1 && blurElems.length ) { - blurElems.not( 'body' ).blur(); - } - - // Focus the inputs - else { - focusableElems.first().focus(); - } - } - - // Steal focus from elements outside tooltip - function stealFocus( event ) { - if ( !elem.is( ':visible' ) ) { - return; - } - - var target = $( event.target ), - tooltip = current.tooltip, - container = target.closest( SELECTOR ), - targetOnTop; - - // Determine if input container target is above this - targetOnTop = container.length < 1 ? FALSE : - (parseInt( container[0].style.zIndex, 10 ) > parseInt( tooltip[0].style.zIndex, 10 )); - - // If we're showing a modal, but focus has landed on an input below - // this modal, divert focus to the first visible input in this modal - // or if we can't find one... the tooltip itself - if ( !targetOnTop && target.closest( SELECTOR )[0] !== tooltip[0] ) { - focusInputs( target ); - } - - // Detect when we leave the last focusable element... - onLast = event.target === focusableElems[focusableElems.length - 1]; - } - - $.extend( - self, { - init: function() { - // Create document overlay - elem = self.elem = $( - '
    ', { - id: 'qtip-overlay', - html: '
    ', - mousedown: function() { - return FALSE; - } - } - ) - .hide(); - - // Make sure we can't focus anything outside the tooltip - $( document.body ).bind( 'focusin' + MODALSELECTOR, stealFocus ); - - // Apply keyboard "Escape key" close handler - $( document ).bind( - 'keydown' + MODALSELECTOR, function( event ) { - if ( current && current.options.show.modal.escape && event.keyCode === 27 ) { - current.hide( event ); - } - } - ); - - // Apply click handler for blur option - elem.bind( - 'click' + MODALSELECTOR, function( event ) { - if ( current && current.options.show.modal.blur ) { - current.hide( event ); - } - } - ); - - return self; - }, - - update: function( api ) { - // Update current API reference - current = api; - - // Update focusable elements if enabled - if ( api.options.show.modal.stealfocus !== FALSE ) { - focusableElems = api.tooltip.find( '*' ).filter( - function() { - return focusable( this ); - } - ); - } - else { - focusableElems = []; - } - }, - - toggle: function( api, state, duration ) { - var docBody = $( document.body ), - tooltip = api.tooltip, - options = api.options.show.modal, - effect = options.effect, - type = state ? 'show' : 'hide', - visible = elem.is( ':visible' ), - visibleModals = $( MODALSELECTOR ).filter( ':visible:not(:animated)' ).not( tooltip ), - zindex; - - // Set active tooltip API reference - self.update( api ); - - // If the modal can steal the focus... - // Blur the current item and focus anything in the modal we an - if ( state && options.stealfocus !== FALSE ) { - focusInputs( $( ':focus' ) ); - } - - // Toggle backdrop cursor style on show - elem.toggleClass( 'blurs', options.blur ); - - // Append to body on show - if ( state ) { - elem.appendTo( document.body ); - } - - // Prevent modal from conflicting with show.solo, and don't hide backdrop is other modals are visible - if ( (elem.is( ':animated' ) && visible === state && prevState !== FALSE) || (!state && visibleModals.length) ) { - return self; - } - - // Stop all animations - elem.stop( TRUE, FALSE ); - - // Use custom function if provided - if ( $.isFunction( effect ) ) { - effect.call( elem, state ); - } - - // If no effect type is supplied, use a simple toggle - else if ( effect === FALSE ) { - elem[type](); - } - - // Use basic fade function - else { - elem.fadeTo( - parseInt( duration, 10 ) || 90, state ? 1 : 0, function() { - if ( !state ) { - elem.hide(); - } - } - ); - } - - // Reset position and detach from body on hide - if ( !state ) { - elem.queue( - function( next ) { - elem.css( {left: '', top: ''} ); - if ( !$( MODALSELECTOR ).length ) { - elem.detach(); - } - next(); - } - ); - } - - // Cache the state - prevState = state; - - // If the tooltip is destroyed, set reference to null - if ( current.destroyed ) { - current = NULL; - } - - return self; - } - } - ); - - self.init(); - }; - OVERLAY = new OVERLAY(); - - function Modal( api, options ) { - this.options = options; - this._ns = '-modal'; - - this.init( (this.qtip = api) ); - } - - $.extend( - Modal.prototype, { - init: function( qtip ) { - var tooltip = qtip.tooltip; - - // If modal is disabled... return - if ( !this.options.on ) { - return this; - } - - // Set overlay reference - qtip.elements.overlay = OVERLAY.elem; - - // Add unique attribute so we can grab modal tooltips easily via a SELECTOR, and set z-index - tooltip.addClass( MODALCLASS ).css( - 'z-index', QTIP.modal_zindex + $( MODALSELECTOR ).length - ); - - // Apply our show/hide/focus modal events - qtip._bind( - tooltip, ['tooltipshow', 'tooltiphide'], function( event, api, duration ) { - var oEvent = event.originalEvent; - - // Make sure mouseout doesn't trigger a hide when showing the modal and mousing onto backdrop - if ( event.target === tooltip[0] ) { - if ( oEvent && event.type === 'tooltiphide' && /mouse(leave|enter)/.test( oEvent.type ) && $( oEvent.relatedTarget ).closest( OVERLAY.elem[0] ).length ) { - try { - event.preventDefault(); - } catch ( e ) { - } - } - else if ( !oEvent || (oEvent && oEvent.type !== 'tooltipsolo') ) { - this.toggle( event, event.type === 'tooltipshow', duration ); - } - } - }, this._ns, this - ); - - // Adjust modal z-index on tooltip focus - qtip._bind( - tooltip, 'tooltipfocus', function( event, api ) { - // If focus was cancelled before it reached us, don't do anything - if ( event.isDefaultPrevented() || event.target !== tooltip[0] ) { - return; - } - - var qtips = $( MODALSELECTOR ), - - // Keep the modal's lower than other, regular qtips - newIndex = QTIP.modal_zindex + qtips.length, - curIndex = parseInt( tooltip[0].style.zIndex, 10 ); - - // Set overlay z-index - OVERLAY.elem[0].style.zIndex = newIndex - 1; - - // Reduce modal z-index's and keep them properly ordered - qtips.each( - function() { - if ( this.style.zIndex > curIndex ) { - this.style.zIndex -= 1; - } - } - ); - - // Fire blur event for focused tooltip - qtips.filter( '.' + CLASS_FOCUS ).qtip( 'blur', event.originalEvent ); - - // Set the new z-index - tooltip.addClass( CLASS_FOCUS )[0].style.zIndex = newIndex; - - // Set current - OVERLAY.update( api ); - - // Prevent default handling - try { - event.preventDefault(); - } catch ( e ) { - } - }, this._ns, this - ); - - // Focus any other visible modals when this one hides - qtip._bind( - tooltip, 'tooltiphide', function( event ) { - if ( event.target === tooltip[0] ) { - $( MODALSELECTOR ).filter( ':visible' ).not( tooltip ).last().qtip( - 'focus', event - ); - } - }, this._ns, this - ); - }, - - toggle: function( event, state, duration ) { - // Make sure default event hasn't been prevented - if ( event && event.isDefaultPrevented() ) { - return this; - } - - // Toggle it - OVERLAY.toggle( this.qtip, !!state, duration ); - }, - - destroy: function() { - // Remove modal class - this.qtip.tooltip.removeClass( MODALCLASS ); - - // Remove bound events - this.qtip._unbind( this.qtip.tooltip, this._ns ); - - // Delete element reference - OVERLAY.toggle( this.qtip, FALSE ); - delete this.qtip.elements.overlay; - } - } - ); - - - MODAL = PLUGINS.modal = function( api ) { - return new Modal( api, api.options.show.modal ); - }; - - // Setup sanitiztion rules - MODAL.sanitize = function( opts ) { - if ( opts.show ) { - if ( typeof opts.show.modal !== 'object' ) { - opts.show.modal = {on: !!opts.show.modal}; - } - else if ( typeof opts.show.modal.on === 'undefined' ) { - opts.show.modal.on = TRUE; - } - } - }; - - // Base z-index for all modal tooltips (use qTip core z-index as a base) - QTIP.modal_zindex = QTIP.zindex - 200; - - // Plugin needs to be initialized on render - MODAL.initialize = 'render'; - - // Setup option set checks - CHECKS.modal = { - '^show.modal.(on|blur)$': function() { - // Initialise - this.destroy(); - this.init(); - - // Show the modal if not visible already and tooltip is visible - this.qtip.elems.overlay.toggle( - this.qtip.tooltip[0].offsetWidth > 0 - ); - } - }; - - // Extend original api defaults - $.extend( - TRUE, QTIP.defaults, { - show: { - modal: { - on: FALSE, - effect: TRUE, - blur: TRUE, - stealfocus: TRUE, - escape: TRUE - } - } - } - ); - ; - PLUGINS.viewport = function( api, position, posOptions, targetWidth, targetHeight, elemWidth, elemHeight ) { - var target = posOptions.target, - tooltip = api.elements.tooltip, - my = posOptions.my, - at = posOptions.at, - adjust = posOptions.adjust, - method = adjust.method.split( ' ' ), - methodX = method[0], - methodY = method[1] || method[0], - viewport = posOptions.viewport, - container = posOptions.container, - cache = api.cache, - adjusted = {left: 0, top: 0}, - fixed, newMy, newClass, containerOffset, containerStatic, - viewportWidth, viewportHeight, viewportScroll, viewportOffset; - - // If viewport is not a jQuery element, or it's the window/document, or no adjustment method is used... return - if ( !viewport.jquery || target[0] === window || target[0] === document.body || adjust.method === 'none' ) { - return adjusted; - } - - // Cach container details - containerOffset = container.offset() || adjusted; - containerStatic = container.css( 'position' ) === 'static'; - - // Cache our viewport details - fixed = tooltip.css( 'position' ) === 'fixed'; - viewportWidth = viewport[0] === window ? viewport.width() : viewport.outerWidth( FALSE ); - viewportHeight = viewport[0] === window ? viewport.height() : viewport.outerHeight( FALSE ); - viewportScroll = {left: fixed ? 0 : viewport.scrollLeft(), top: fixed ? 0 : viewport.scrollTop()}; - viewportOffset = viewport.offset() || adjusted; - - // Generic calculation method - function calculate( side, otherSide, type, adjust, side1, side2, lengthName, targetLength, elemLength ) { - var initialPos = position[side1], - mySide = my[side], - atSide = at[side], - isShift = type === SHIFT, - myLength = mySide === side1 ? elemLength : mySide === side2 ? -elemLength : -elemLength / 2, - atLength = atSide === side1 ? targetLength : atSide === side2 ? -targetLength : -targetLength / 2, - sideOffset = viewportScroll[side1] + viewportOffset[side1] - (containerStatic ? 0 : containerOffset[side1]), - overflow1 = sideOffset - initialPos, - overflow2 = initialPos + elemLength - (lengthName === WIDTH ? viewportWidth : viewportHeight) - sideOffset, - offset = myLength - (my.precedance === side || mySide === my[otherSide] ? atLength : 0) - (atSide === CENTER ? targetLength / 2 : 0); - - // shift - if ( isShift ) { - offset = (mySide === side1 ? 1 : -1) * myLength; - - // Adjust position but keep it within viewport dimensions - position[side1] += overflow1 > 0 ? overflow1 : overflow2 > 0 ? -overflow2 : 0; - position[side1] = Math.max( - -containerOffset[side1] + viewportOffset[side1], - initialPos - offset, - Math.min( - Math.max( - -containerOffset[side1] + viewportOffset[side1] + (lengthName === WIDTH ? viewportWidth : viewportHeight), - initialPos + offset - ), - position[side1], - - // Make sure we don't adjust complete off the element when using 'center' - mySide === 'center' ? initialPos - myLength : 1E9 - ) - ); - - } - - // flip/flipinvert - else { - // Update adjustment amount depending on if using flipinvert or flip - adjust *= (type === FLIPINVERT ? 2 : 0); - - // Check for overflow on the left/top - if ( overflow1 > 0 && (mySide !== side1 || overflow2 > 0) ) { - position[side1] -= offset + adjust; - newMy.invert( side, side1 ); - } - - // Check for overflow on the bottom/right - else if ( overflow2 > 0 && (mySide !== side2 || overflow1 > 0) ) { - position[side1] -= (mySide === CENTER ? -offset : offset) + adjust; - newMy.invert( side, side2 ); - } - - // Make sure we haven't made things worse with the adjustment and reset if so - if ( position[side1] < viewportScroll && -position[side1] > overflow2 ) { - position[side1] = initialPos; - newMy = my.clone(); - } - } - - return position[side1] - initialPos; - } - - // Set newMy if using flip or flipinvert methods - if ( methodX !== 'shift' || methodY !== 'shift' ) { - newMy = my.clone(); - } - - // Adjust position based onviewport and adjustment options - adjusted = { - left: methodX !== 'none' ? calculate( - X, Y, methodX, adjust.x, LEFT, RIGHT, WIDTH, targetWidth, elemWidth - ) : 0, - top: methodY !== 'none' ? calculate( - Y, X, methodY, adjust.y, TOP, BOTTOM, HEIGHT, targetHeight, elemHeight - ) : 0 - }; - - // Set tooltip position class if it's changed - if ( newMy && cache.lastClass !== (newClass = NAMESPACE + '-pos-' + newMy.abbrev()) ) { - tooltip.removeClass( api.cache.lastClass ).addClass( (api.cache.lastClass = newClass) ); - } - - return adjusted; - }; - ; - PLUGINS.polys = { - // POLY area coordinate calculator - // Special thanks to Ed Cradock for helping out with this. - // Uses a binary search algorithm to find suitable coordinates. - polygon: function( baseCoords, corner ) { - var result = { - width: 0, height: 0, - position: { - top: 1e10, right: 0, - bottom: 0, left: 1e10 - }, - adjustable: FALSE - }, - i = 0, next, - coords = [], - compareX = 1, compareY = 1, - realX = 0, realY = 0, - newWidth, newHeight; - - // First pass, sanitize coords and determine outer edges - i = baseCoords.length; - while ( i-- ) { - next = [parseInt( baseCoords[--i], 10 ), parseInt( baseCoords[i + 1], 10 )]; - - if ( next[0] > result.position.right ) { - result.position.right = next[0]; - } - if ( next[0] < result.position.left ) { - result.position.left = next[0]; - } - if ( next[1] > result.position.bottom ) { - result.position.bottom = next[1]; - } - if ( next[1] < result.position.top ) { - result.position.top = next[1]; - } - - coords.push( next ); - } - - // Calculate height and width from outer edges - newWidth = result.width = Math.abs( result.position.right - result.position.left ); - newHeight = result.height = Math.abs( result.position.bottom - result.position.top ); - - // If it's the center corner... - if ( corner.abbrev() === 'c' ) { - result.position = { - left: result.position.left + (result.width / 2), - top: result.position.top + (result.height / 2) - }; - } - else { - // Second pass, use a binary search algorithm to locate most suitable coordinate - while ( newWidth > 0 && newHeight > 0 && compareX > 0 && compareY > 0 ) { - newWidth = Math.floor( newWidth / 2 ); - newHeight = Math.floor( newHeight / 2 ); - - if ( corner.x === LEFT ) { - compareX = newWidth; - } - else if ( corner.x === RIGHT ) { - compareX = result.width - newWidth; - } - else { - compareX += Math.floor( newWidth / 2 ); - } - - if ( corner.y === TOP ) { - compareY = newHeight; - } - else if ( corner.y === BOTTOM ) { - compareY = result.height - newHeight; - } - else { - compareY += Math.floor( newHeight / 2 ); - } - - i = coords.length; - while ( i-- ) { - if ( coords.length < 2 ) { - break; - } - - realX = coords[i][0] - result.position.left; - realY = coords[i][1] - result.position.top; - - if ( (corner.x === LEFT && realX >= compareX) || - (corner.x === RIGHT && realX <= compareX) || - (corner.x === CENTER && (realX < compareX || realX > (result.width - compareX))) || - (corner.y === TOP && realY >= compareY) || - (corner.y === BOTTOM && realY <= compareY) || - (corner.y === CENTER && (realY < compareY || realY > (result.height - compareY))) ) { - coords.splice( i, 1 ); - } - } - } - result.position = {left: coords[0][0], top: coords[0][1]}; - } - - return result; - }, - - rect: function( ax, ay, bx, by ) { - return { - width: Math.abs( bx - ax ), - height: Math.abs( by - ay ), - position: { - left: Math.min( ax, bx ), - top: Math.min( ay, by ) - } - }; - }, - - _angles: { - tc: 3 / 2, tr: 7 / 4, tl: 5 / 4, - bc: 1 / 2, br: 1 / 4, bl: 3 / 4, - rc: 2, lc: 1, c: 0 - }, - ellipse: function( cx, cy, rx, ry, corner ) { - var c = PLUGINS.polys._angles[corner.abbrev()], - rxc = c === 0 ? 0 : rx * Math.cos( c * Math.PI ), - rys = ry * Math.sin( c * Math.PI ); - - return { - width: (rx * 2) - Math.abs( rxc ), - height: (ry * 2) - Math.abs( rys ), - position: { - left: cx + rxc, - top: cy + rys - }, - adjustable: FALSE - }; - }, - circle: function( cx, cy, r, corner ) { - return PLUGINS.polys.ellipse( cx, cy, r, r, corner ); - } - }; - ; - PLUGINS.svg = function( api, svg, corner ) { - var doc = $( document ), - elem = svg[0], - root = $( elem.ownerSVGElement ), - xScale = 1, yScale = 1, - complex = true, - rootWidth, rootHeight, - mtx, transformed, viewBox, - len, next, i, points, - result, position, dimensions; - - // Ascend the parentNode chain until we find an element with getBBox() - while ( !elem.getBBox ) { - elem = elem.parentNode; - } - if ( !elem.getBBox || !elem.parentNode ) { - return FALSE; - } - - // Determine dimensions where possible - rootWidth = root.attr( 'width' ) || root.width() || parseInt( root.css( 'width' ), 10 ); - rootHeight = root.attr( 'height' ) || root.height() || parseInt( root.css( 'height' ), 10 ); - - // Add stroke characteristics to scaling - var strokeWidth2 = (parseInt( svg.css( 'stroke-width' ), 10 ) || 0) / 2; - if ( strokeWidth2 ) { - xScale += strokeWidth2 / rootWidth; - yScale += strokeWidth2 / rootHeight; - } - - // Determine which shape calculation to use - switch ( elem.nodeName ) { - case 'ellipse': - case 'circle': - result = PLUGINS.polys.ellipse( - elem.cx.baseVal.value, - elem.cy.baseVal.value, - (elem.rx || elem.r).baseVal.value + strokeWidth2, - (elem.ry || elem.r).baseVal.value + strokeWidth2, - corner - ); - break; - - case 'line': - case 'polygon': - case 'polyline': - // Determine points object (line has none, so mimic using array) - points = elem.points || [ - {x: elem.x1.baseVal.value, y: elem.y1.baseVal.value}, - {x: elem.x2.baseVal.value, y: elem.y2.baseVal.value} - ]; - - for ( result = [], i = -1, len = points.numberOfItems || points.length; ++i < len; ) { - next = points.getItem ? points.getItem( i ) : points[i]; - result.push.apply( result, [next.x, next.y] ); - } - - result = PLUGINS.polys.polygon( result, corner ); - break; - - // Unknown shape or rectangle? Use bounding box - default: - result = elem.getBoundingClientRect(); - result = { - width: result.width, height: result.height, - position: { - left: result.left, - top: result.top - } - }; - complex = false; - break; - } - - // Shortcut assignments - position = result.position; - root = root[0]; - - // If the shape was complex (i.e. not using bounding box calculations) - if ( complex ) { - // Convert position into a pixel value - if ( root.createSVGPoint ) { - mtx = elem.getScreenCTM(); - points = root.createSVGPoint(); - - points.x = position.left; - points.y = position.top; - transformed = points.matrixTransform( mtx ); - position.left = transformed.x; - position.top = transformed.y; - } - - // Calculate viewBox characteristics - if ( root.viewBox && (viewBox = root.viewBox.baseVal) && viewBox.width && viewBox.height ) { - xScale *= rootWidth / viewBox.width; - yScale *= rootHeight / viewBox.height; - } - } - - // Adjust by scroll offset - position.left += doc.scrollLeft(); - position.top += doc.scrollTop(); - - return result; - }; - ; - PLUGINS.imagemap = function( api, area, corner, adjustMethod ) { - if ( !area.jquery ) { - area = $( area ); - } - - var shape = area.attr( 'shape' ).toLowerCase().replace( 'poly', 'polygon' ), - image = $( 'img[usemap="#' + area.parent( 'map' ).attr( 'name' ) + '"]' ), - coordsString = $.trim( area.attr( 'coords' ) ), - coordsArray = coordsString.replace( /,$/, '' ).split( ',' ), - imageOffset, coords, i, next, result, len; - - // If we can't find the image using the map... - if ( !image.length ) { - return FALSE; - } - - // Pass coordinates string if polygon - if ( shape === 'polygon' ) { - result = PLUGINS.polys.polygon( coordsArray, corner ); - } - - // Otherwise parse the coordinates and pass them as arguments - else if ( PLUGINS.polys[shape] ) { - for ( i = -1, len = coordsArray.length, coords = []; ++i < len; ) { - coords.push( parseInt( coordsArray[i], 10 ) ); - } - - result = PLUGINS.polys[shape].apply( - this, coords.concat( corner ) - ); - } - - // If no shapre calculation method was found, return false - else { - return FALSE; - } - - // Make sure we account for padding and borders on the image - imageOffset = image.offset(); - imageOffset.left += Math.ceil( (image.outerWidth( FALSE ) - image.width()) / 2 ); - imageOffset.top += Math.ceil( (image.outerHeight( FALSE ) - image.height()) / 2 ); - - // Add image position to offset coordinates - result.position.left += imageOffset.left; - result.position.top += imageOffset.top; - - return result; - }; - ; - var IE6, - - /* - * BGIFrame adaption (http://plugins.jquery.com/project/bgiframe) - * Special thanks to Brandon Aaron - */ - BGIFRAME = ''; - - function Ie6( api, qtip ) { - this._ns = 'ie6'; - this.init( (this.qtip = api) ); - } - - $.extend( - Ie6.prototype, { - _scroll: function() { - var overlay = this.qtip.elements.overlay; - overlay && (overlay[0].style.top = $( window ).scrollTop() + 'px'); - }, - - init: function( qtip ) { - var tooltip = qtip.tooltip, - scroll; - - // Create the BGIFrame element if needed - if ( $( 'select, object' ).length < 1 ) { - this.bgiframe = qtip.elements.bgiframe = $( BGIFRAME ).appendTo( tooltip ); - - // Update BGIFrame on tooltip move - qtip._bind( tooltip, 'tooltipmove', this.adjustBGIFrame, this._ns, this ); - } - - // redraw() container for width/height calculations - this.redrawContainer = $( '
    ', {id: NAMESPACE + '-rcontainer'} ) - .appendTo( document.body ); - - // Fixup modal plugin if present too - if ( qtip.elements.overlay && qtip.elements.overlay.addClass( 'qtipmodal-ie6fix' ) ) { - qtip._bind( window, ['scroll', 'resize'], this._scroll, this._ns, this ); - qtip._bind( tooltip, ['tooltipshow'], this._scroll, this._ns, this ); - } - - // Set dimensions - this.redraw(); - }, - - adjustBGIFrame: function() { - var tooltip = this.qtip.tooltip, - dimensions = { - height: tooltip.outerHeight( FALSE ), - width: tooltip.outerWidth( FALSE ) - }, - plugin = this.qtip.plugins.tip, - tip = this.qtip.elements.tip, - tipAdjust, offset; - - // Adjust border offset - offset = parseInt( tooltip.css( 'borderLeftWidth' ), 10 ) || 0; - offset = {left: -offset, top: -offset}; - - // Adjust for tips plugin - if ( plugin && tip ) { - tipAdjust = (plugin.corner.precedance === 'x') ? [WIDTH, LEFT] : [HEIGHT, TOP]; - offset[tipAdjust[1]] -= tip[tipAdjust[0]](); - } - - // Update bgiframe - this.bgiframe.css( offset ).css( dimensions ); - }, - - // Max/min width simulator function - redraw: function() { - if ( this.qtip.rendered < 1 || this.drawing ) { - return this; - } - - var tooltip = this.qtip.tooltip, - style = this.qtip.options.style, - container = this.qtip.options.position.container, - perc, width, max, min; - - // Set drawing flag - this.qtip.drawing = 1; - - // If tooltip has a set height/width, just set it... like a boss! - if ( style.height ) { - tooltip.css( HEIGHT, style.height ); - } - if ( style.width ) { - tooltip.css( WIDTH, style.width ); - } - - // Simulate max/min width if not set width present... - else { - // Reset width and add fluid class - tooltip.css( WIDTH, '' ).appendTo( this.redrawContainer ); - - // Grab our tooltip width (add 1 if odd so we don't get wrapping problems.. huzzah!) - width = tooltip.width(); - if ( width % 2 < 1 ) { - width += 1; - } - - // Grab our max/min properties - max = tooltip.css( 'maxWidth' ) || ''; - min = tooltip.css( 'minWidth' ) || ''; - - // Parse into proper pixel values - perc = (max + min).indexOf( '%' ) > -1 ? container.width() / 100 : 0; - max = ((max.indexOf( '%' ) > -1 ? perc : 1) * parseInt( max, 10 )) || width; - min = ((min.indexOf( '%' ) > -1 ? perc : 1) * parseInt( min, 10 )) || 0; - - // Determine new dimension size based on max/min/current values - width = max + min ? Math.min( Math.max( width, min ), max ) : width; - - // Set the newly calculated width and remvoe fluid class - tooltip.css( WIDTH, Math.round( width ) ).appendTo( container ); - } - - // Set drawing flag - this.drawing = 0; - - return this; - }, - - destroy: function() { - // Remove iframe - this.bgiframe && this.bgiframe.remove(); - - // Remove bound events - this.qtip._unbind( [window, this.qtip.tooltip], this._ns ); - } - } - ); - - IE6 = PLUGINS.ie6 = function( api ) { - // Proceed only if the browser is IE6 - return BROWSER.ie === 6 ? new Ie6( api ) : FALSE; - }; - - IE6.initialize = 'render'; - - CHECKS.ie6 = { - '^content|style$': function() { - this.redraw(); - } - }; - ; - } - )); - }( window, document )); -} - - - - diff --git a/library/admin/ReduxCore/assets/js/vendor/qtip/jquery.qtip.min.js b/library/admin/ReduxCore/assets/js/vendor/qtip/jquery.qtip.min.js deleted file mode 100644 index 291133fd..00000000 --- a/library/admin/ReduxCore/assets/js/vendor/qtip/jquery.qtip.min.js +++ /dev/null @@ -1,3 +0,0 @@ -/* qTip2 v2.2.0 None | qtip2.com | Licensed MIT, GPL | Sun Dec 15 2013 23:29:05 */ -if ( typeof jQuery.qtip === 'undefined' ) {!function(a,b,c){!function(a){"use strict";"function"==typeof define&&define.amd?define(["jquery"],a):jQuery&&!jQuery.fn.qtip&&a(jQuery)}(function(d){"use strict";function e(a,b,c,e){this.id=c,this.target=a,this.tooltip=A,this.elements={target:a},this._id=J+"-"+c,this.timers={img:{}},this.options=b,this.plugins={},this.cache={event:{},target:d(),disabled:z,attr:e,onTooltip:z,lastClass:""},this.rendered=this.destroyed=this.disabled=this.waiting=this.hiddenDuringWait=this.positioning=this.triggering=z}function f(a){return a===A||"object"!==d.type(a)}function g(a){return!(d.isFunction(a)||a&&a.attr||a.length||"object"===d.type(a)&&(a.jquery||a.then))}function h(a){var b,c,e,h;return f(a)?z:(f(a.metadata)&&(a.metadata={type:a.metadata}),"content"in a&&(b=a.content,f(b)||b.jquery||b.done?b=a.content={text:c=g(b)?z:b}:c=b.text,"ajax"in b&&(e=b.ajax,h=e&&e.once!==z,delete b.ajax,b.text=function(a,b){var f=c||d(this).attr(b.options.content.attr)||"Loading...",g=d.ajax(d.extend({},e,{context:b})).then(e.success,A,e.error).then(function(a){return a&&h&&b.set("content.text",a),a},function(a,c,d){b.destroyed||0===a.status||b.set("content.text",c+": "+d)});return h?f:(b.set("content.text",f),g)}),"title"in b&&(f(b.title)||(b.button=b.title.button,b.title=b.title.text),g(b.title||z)&&(b.title=z))),"position"in a&&f(a.position)&&(a.position={my:a.position,at:a.position}),"show"in a&&f(a.show)&&(a.show=a.show.jquery?{target:a.show}:a.show===y?{ready:y}:{event:a.show}),"hide"in a&&f(a.hide)&&(a.hide=a.hide.jquery?{target:a.hide}:{event:a.hide}),"style"in a&&f(a.style)&&(a.style={classes:a.style}),d.each(I,function(){this.sanitize&&this.sanitize(a)}),a)}function i(a,b){for(var c,d=0,e=a,f=b.split(".");e=e[f[d++]];)d0?setTimeout(d.proxy(a,this),b):(a.call(this),void 0)}function n(a){return this.tooltip.hasClass(T)?z:(clearTimeout(this.timers.show),clearTimeout(this.timers.hide),this.timers.show=m.call(this,function(){this.toggle(y,a)},this.options.show.delay),void 0)}function o(a){if(this.tooltip.hasClass(T))return z;var b=d(a.relatedTarget),c=b.closest(N)[0]===this.tooltip[0],e=b[0]===this.options.show.target[0];if(clearTimeout(this.timers.show),clearTimeout(this.timers.hide),this!==b[0]&&"mouse"===this.options.position.target&&c||this.options.hide.fixed&&/mouse(out|leave|move)/.test(a.type)&&(c||e))try{a.preventDefault(),a.stopImmediatePropagation()}catch(f){}else this.timers.hide=m.call(this,function(){this.toggle(z,a)},this.options.hide.delay,this)}function p(a){return this.tooltip.hasClass(T)||!this.options.hide.inactive?z:(clearTimeout(this.timers.inactive),this.timers.inactive=m.call(this,function(){this.hide(a)},this.options.hide.inactive),void 0)}function q(a){this.rendered&&this.tooltip[0].offsetWidth>0&&this.reposition(a)}function r(a,c,e){d(b.body).delegate(a,(c.split?c:c.join($+" "))+$,function(){var a=t.api[d.attr(this,L)];a&&!a.disabled&&e.apply(a,arguments)})}function s(a,c,f){var g,i,j,k,l,m=d(b.body),n=a[0]===b?m:a,o=a.metadata?a.metadata(f.metadata):A,p="html5"===f.metadata.type&&o?o[f.metadata.name]:A,q=a.data(f.metadata.name||"qtipopts");try{q="string"==typeof q?d.parseJSON(q):q}catch(r){}if(k=d.extend(y,{},t.defaults,f,"object"==typeof q?h(q):A,h(p||o)),i=k.position,k.id=c,"boolean"==typeof k.content.text){if(j=a.attr(k.content.attr),k.content.attr===z||!j)return z;k.content.text=j}if(i.container.length||(i.container=m),i.target===z&&(i.target=n),k.show.target===z&&(k.show.target=n),k.show.solo===y&&(k.show.solo=i.container.closest("body")),k.hide.target===z&&(k.hide.target=n),k.position.viewport===y&&(k.position.viewport=i.container),i.container=i.container.eq(0),i.at=new v(i.at,y),i.my=new v(i.my),a.data(J))if(k.overwrite)a.qtip("destroy",!0);else if(k.overwrite===z)return z;return a.attr(K,c),k.suppress&&(l=a.attr("title"))&&a.removeAttr("title").attr(V,l).attr("title",""),g=new e(a,k,c,!!j),a.data(J,g),a.one("remove.qtip-"+c+" removeqtip.qtip-"+c,function(){var a;(a=d(this).data(J))&&a.destroy(!0)}),g}var t,u,v,w,x,y=!0,z=!1,A=null,B="x",C="y",D="top",E="left",F="bottom",G="right",H="center",I={},J="qtip",K="data-hasqtip",L="data-qtip-id",M=["ui-widget","ui-tooltip"],N="."+J,O="click dblclick mousedown mouseup mousemove mouseleave mouseenter".split(" "),P=J+"-fixed",Q=J+"-default",R=J+"-focus",S=J+"-hover",T=J+"-disabled",U="_replacedByqTip",V="oldtitle",W={ie:function(){for(var a=3,c=b.createElement("div");(c.innerHTML="")&&c.getElementsByTagName("i")[0];);return a>4?a:0/0}(),iOS:parseFloat((""+(/CPU.*OS ([0-9_]{1,5})|(CPU like).*AppleWebKit.*Mobile/i.exec(navigator.userAgent)||[0,""])[1]).replace("undefined","3_2").replace("_",".").replace("_",""))||z};u=e.prototype,u._when=function(a){return d.when.apply(d,a)},u.render=function(a){if(this.rendered||this.destroyed)return this;var b,c=this,e=this.options,f=this.cache,g=this.elements,h=e.content.text,i=e.content.title,j=e.content.button,k=e.position,l=("."+this._id+" ",[]);return d.attr(this.target[0],"aria-describedby",this._id),this.tooltip=g.tooltip=b=d("
    ",{id:this._id,"class":[J,Q,e.style.classes,J+"-pos-"+e.position.my.abbrev()].join(" "),width:e.style.width||"",height:e.style.height||"",tracking:"mouse"===k.target&&k.adjust.mouse,role:"alert","aria-live":"polite","aria-atomic":z,"aria-describedby":this._id+"-content","aria-hidden":y}).toggleClass(T,this.disabled).attr(L,this.id).data(J,this).appendTo(k.container).append(g.content=d("
    ",{"class":J+"-content",id:this._id+"-content","aria-atomic":y})),this.rendered=-1,this.positioning=y,i&&(this._createTitle(),d.isFunction(i)||l.push(this._updateTitle(i,z))),j&&this._createButton(),d.isFunction(h)||l.push(this._updateContent(h,z)),this.rendered=y,this._setWidget(),d.each(I,function(a){var b;"render"===this.initialize&&(b=this(c))&&(c.plugins[a]=b)}),this._unassignEvents(),this._assignEvents(),this._when(l).then(function(){c._trigger("render"),c.positioning=z,c.hiddenDuringWait||!e.show.ready&&!a||c.toggle(y,f.event,z),c.hiddenDuringWait=z}),t.api[this.id]=this,this},u.destroy=function(a){function b(){if(!this.destroyed){this.destroyed=y;var a=this.target,b=a.attr(V);this.rendered&&this.tooltip.stop(1,0).find("*").remove().end().remove(),d.each(this.plugins,function(){this.destroy&&this.destroy()}),clearTimeout(this.timers.show),clearTimeout(this.timers.hide),this._unassignEvents(),a.removeData(J).removeAttr(L).removeAttr(K).removeAttr("aria-describedby"),this.options.suppress&&b&&a.attr("title",b).removeAttr(V),this._unbind(a),this.options=this.elements=this.cache=this.timers=this.plugins=this.mouse=A,delete t.api[this.id]}}return this.destroyed?this.target:(a===y&&"hide"!==this.triggering||!this.rendered?b.call(this):(this.tooltip.one("tooltiphidden",d.proxy(b,this)),!this.triggering&&this.hide()),this.target)},w=u.checks={builtin:{"^id$":function(a,b,c,e){var f=c===y?t.nextid:c,g=J+"-"+f;f!==z&&f.length>0&&!d("#"+g).length?(this._id=g,this.rendered&&(this.tooltip[0].id=this._id,this.elements.content[0].id=this._id+"-content",this.elements.title[0].id=this._id+"-title")):a[b]=e},"^prerender":function(a,b,c){c&&!this.rendered&&this.render(this.options.show.ready)},"^content.text$":function(a,b,c){this._updateContent(c)},"^content.attr$":function(a,b,c,d){this.options.content.text===this.target.attr(d)&&this._updateContent(this.target.attr(c))},"^content.title$":function(a,b,c){return c?(c&&!this.elements.title&&this._createTitle(),this._updateTitle(c),void 0):this._removeTitle()},"^content.button$":function(a,b,c){this._updateButton(c)},"^content.title.(text|button)$":function(a,b,c){this.set("content."+b,c)},"^position.(my|at)$":function(a,b,c){"string"==typeof c&&(a[b]=new v(c,"at"===b))},"^position.container$":function(a,b,c){this.rendered&&this.tooltip.appendTo(c)},"^show.ready$":function(a,b,c){c&&(!this.rendered&&this.render(y)||this.toggle(y))},"^style.classes$":function(a,b,c,d){this.rendered&&this.tooltip.removeClass(d).addClass(c)},"^style.(width|height)":function(a,b,c){this.rendered&&this.tooltip.css(b,c)},"^style.widget|content.title":function(){this.rendered&&this._setWidget()},"^style.def":function(a,b,c){this.rendered&&this.tooltip.toggleClass(Q,!!c)},"^events.(render|show|move|hide|focus|blur)$":function(a,b,c){this.rendered&&this.tooltip[(d.isFunction(c)?"":"un")+"bind"]("tooltip"+b,c)},"^(show|hide|position).(event|target|fixed|inactive|leave|distance|viewport|adjust)":function(){if(this.rendered){var a=this.options.position;this.tooltip.attr("tracking","mouse"===a.target&&a.adjust.mouse),this._unassignEvents(),this._assignEvents()}}}},u.get=function(a){if(this.destroyed)return this;var b=i(this.options,a.toLowerCase()),c=b[0][b[1]];return c.precedance?c.string():c};var X=/^position\.(my|at|adjust|target|container|viewport)|style|content|show\.ready/i,Y=/^prerender|show\.ready/i;u.set=function(a,b){if(this.destroyed)return this;{var c,e=this.rendered,f=z,g=this.options;this.checks}return"string"==typeof a?(c=a,a={},a[c]=b):a=d.extend({},a),d.each(a,function(b,c){if(e&&Y.test(b))return delete a[b],void 0;var h,j=i(g,b.toLowerCase());h=j[0][j[1]],j[0][j[1]]=c&&c.nodeType?d(c):c,f=X.test(b)||f,a[b]=[j[0],j[1],c,h]}),h(g),this.positioning=y,d.each(a,d.proxy(j,this)),this.positioning=z,this.rendered&&this.tooltip[0].offsetWidth>0&&f&&this.reposition("mouse"===g.position.target?A:this.cache.event),this},u._update=function(a,b){var c=this,e=this.cache;return this.rendered&&a?(d.isFunction(a)&&(a=a.call(this.elements.target,e.event,this)||""),d.isFunction(a.then)?(e.waiting=y,a.then(function(a){return e.waiting=z,c._update(a,b)},A,function(a){return c._update(a,b)})):a===z||!a&&""!==a?z:(a.jquery&&a.length>0?b.empty().append(a.css({display:"block",visibility:"visible"})):b.html(a),this._waitForContent(b).then(function(a){a.images&&a.images.length&&c.rendered&&c.tooltip[0].offsetWidth>0&&c.reposition(e.event,!a.length)}))):z},u._waitForContent=function(a){var b=this.cache;return b.waiting=y,(d.fn.imagesLoaded?a.imagesLoaded():d.Deferred().resolve([])).done(function(){b.waiting=z}).promise()},u._updateContent=function(a,b){this._update(a,this.elements.content,b)},u._updateTitle=function(a,b){this._update(a,this.elements.title,b)===z&&this._removeTitle(z)},u._createTitle=function(){var a=this.elements,b=this._id+"-title";a.titlebar&&this._removeTitle(),a.titlebar=d("
    ",{"class":J+"-titlebar "+(this.options.style.widget?k("header"):"")}).append(a.title=d("
    ",{id:b,"class":J+"-title","aria-atomic":y})).insertBefore(a.content).delegate(".qtip-close","mousedown keydown mouseup keyup mouseout",function(a){d(this).toggleClass("ui-state-active ui-state-focus","down"===a.type.substr(-4))}).delegate(".qtip-close","mouseover mouseout",function(a){d(this).toggleClass("ui-state-hover","mouseover"===a.type)}),this.options.content.button&&this._createButton()},u._removeTitle=function(a){var b=this.elements;b.title&&(b.titlebar.remove(),b.titlebar=b.title=b.button=A,a!==z&&this.reposition())},u.reposition=function(c,e){if(!this.rendered||this.positioning||this.destroyed)return this;this.positioning=y;var f,g,h=this.cache,i=this.tooltip,j=this.options.position,k=j.target,l=j.my,m=j.at,n=j.viewport,o=j.container,p=j.adjust,q=p.method.split(" "),r=i.outerWidth(z),s=i.outerHeight(z),t=0,u=0,v=i.css("position"),w={left:0,top:0},x=i[0].offsetWidth>0,A=c&&"scroll"===c.type,B=d(a),C=o[0].ownerDocument,J=this.mouse;if(d.isArray(k)&&2===k.length)m={x:E,y:D},w={left:k[0],top:k[1]};else if("mouse"===k)m={x:E,y:D},!J||!J.pageX||!p.mouse&&c&&c.pageX?c&&c.pageX||((!p.mouse||this.options.show.distance)&&h.origin&&h.origin.pageX?c=h.origin:(!c||c&&("resize"===c.type||"scroll"===c.type))&&(c=h.event)):c=J,"static"!==v&&(w=o.offset()),C.body.offsetWidth!==(a.innerWidth||C.documentElement.clientWidth)&&(g=d(b.body).offset()),w={left:c.pageX-w.left+(g&&g.left||0),top:c.pageY-w.top+(g&&g.top||0)},p.mouse&&A&&J&&(w.left-=(J.scrollX||0)-B.scrollLeft(),w.top-=(J.scrollY||0)-B.scrollTop());else{if("event"===k?c&&c.target&&"scroll"!==c.type&&"resize"!==c.type?h.target=d(c.target):c.target||(h.target=this.elements.target):"event"!==k&&(h.target=d(k.jquery?k:this.elements.target)),k=h.target,k=d(k).eq(0),0===k.length)return this;k[0]===b||k[0]===a?(t=W.iOS?a.innerWidth:k.width(),u=W.iOS?a.innerHeight:k.height(),k[0]===a&&(w={top:(n||k).scrollTop(),left:(n||k).scrollLeft()})):I.imagemap&&k.is("area")?f=I.imagemap(this,k,m,I.viewport?q:z):I.svg&&k&&k[0].ownerSVGElement?f=I.svg(this,k,m,I.viewport?q:z):(t=k.outerWidth(z),u=k.outerHeight(z),w=k.offset()),f&&(t=f.width,u=f.height,g=f.offset,w=f.position),w=this.reposition.offset(k,w,o),(W.iOS>3.1&&W.iOS<4.1||W.iOS>=4.3&&W.iOS<4.33||!W.iOS&&"fixed"===v)&&(w.left-=B.scrollLeft(),w.top-=B.scrollTop()),(!f||f&&f.adjustable!==z)&&(w.left+=m.x===G?t:m.x===H?t/2:0,w.top+=m.y===F?u:m.y===H?u/2:0)}return w.left+=p.x+(l.x===G?-r:l.x===H?-r/2:0),w.top+=p.y+(l.y===F?-s:l.y===H?-s/2:0),I.viewport?(w.adjusted=I.viewport(this,w,j,t,u,r,s),g&&w.adjusted.left&&(w.left+=g.left),g&&w.adjusted.top&&(w.top+=g.top)):w.adjusted={left:0,top:0},this._trigger("move",[w,n.elem||n],c)?(delete w.adjusted,e===z||!x||isNaN(w.left)||isNaN(w.top)||"mouse"===k||!d.isFunction(j.effect)?i.css(w):d.isFunction(j.effect)&&(j.effect.call(i,this,d.extend({},w)),i.queue(function(a){d(this).css({opacity:"",height:""}),W.ie&&this.style.removeAttribute("filter"),a()})),this.positioning=z,this):this},u.reposition.offset=function(a,c,e){function f(a,b){c.left+=b*a.scrollLeft(),c.top+=b*a.scrollTop()}if(!e[0])return c;var g,h,i,j,k=d(a[0].ownerDocument),l=!!W.ie&&"CSS1Compat"!==b.compatMode,m=e[0];do"static"!==(h=d.css(m,"position"))&&("fixed"===h?(i=m.getBoundingClientRect(),f(k,-1)):(i=d(m).position(),i.left+=parseFloat(d.css(m,"borderLeftWidth"))||0,i.top+=parseFloat(d.css(m,"borderTopWidth"))||0),c.left-=i.left+(parseFloat(d.css(m,"marginLeft"))||0),c.top-=i.top+(parseFloat(d.css(m,"marginTop"))||0),g||"hidden"===(j=d.css(m,"overflow"))||"visible"===j||(g=d(m)));while(m=m.offsetParent);return g&&(g[0]!==k[0]||l)&&f(g,1),c};var Z=(v=u.reposition.Corner=function(a,b){a=(""+a).replace(/([A-Z])/," $1").replace(/middle/gi,H).toLowerCase(),this.x=(a.match(/left|right/i)||a.match(/center/)||["inherit"])[0].toLowerCase(),this.y=(a.match(/top|bottom|center/i)||["inherit"])[0].toLowerCase(),this.forceY=!!b;var c=a.charAt(0);this.precedance="t"===c||"b"===c?C:B}).prototype;Z.invert=function(a,b){this[a]=this[a]===E?G:this[a]===G?E:b||this[a]},Z.string=function(){var a=this.x,b=this.y;return a===b?a:this.precedance===C||this.forceY&&"center"!==b?b+" "+a:a+" "+b},Z.abbrev=function(){var a=this.string().split(" ");return a[0].charAt(0)+(a[1]&&a[1].charAt(0)||"")},Z.clone=function(){return new v(this.string(),this.forceY)},u.toggle=function(a,c){var e=this.cache,f=this.options,g=this.tooltip;if(c){if(/over|enter/.test(c.type)&&/out|leave/.test(e.event.type)&&f.show.target.add(c.target).length===f.show.target.length&&g.has(c.relatedTarget).length)return this;e.event=l(c)}if(this.waiting&&!a&&(this.hiddenDuringWait=y),!this.rendered)return a?this.render(1):this;if(this.destroyed||this.disabled)return this;var h,i,j,k=a?"show":"hide",m=this.options[k],n=(this.options[a?"hide":"show"],this.options.position),o=this.options.content,p=this.tooltip.css("width"),q=this.tooltip.is(":visible"),r=a||1===m.target.length,s=!c||m.target.length<2||e.target[0]===c.target;return(typeof a).search("boolean|number")&&(a=!q),h=!g.is(":animated")&&q===a&&s,i=h?A:!!this._trigger(k,[90]),this.destroyed?this:(i!==z&&a&&this.focus(c),!i||h?this:(d.attr(g[0],"aria-hidden",!a),a?(e.origin=l(this.mouse),d.isFunction(o.text)&&this._updateContent(o.text,z),d.isFunction(o.title)&&this._updateTitle(o.title,z),!x&&"mouse"===n.target&&n.adjust.mouse&&(d(b).bind("mousemove."+J,this._storeMouse),x=y),p||g.css("width",g.outerWidth(z)),this.reposition(c,arguments[2]),p||g.css("width",""),m.solo&&("string"==typeof m.solo?d(m.solo):d(N,m.solo)).not(g).not(m.target).qtip("hide",d.Event("tooltipsolo"))):(clearTimeout(this.timers.show),delete e.origin,x&&!d(N+'[tracking="true"]:visible',m.solo).not(g).length&&(d(b).unbind("mousemove."+J),x=z),this.blur(c)),j=d.proxy(function(){a?(W.ie&&g[0].style.removeAttribute("filter"),g.css("overflow",""),"string"==typeof m.autofocus&&d(this.options.show.autofocus,g).focus(),this.options.show.target.trigger("qtip-"+this.id+"-inactive")):g.css({display:"",visibility:"",opacity:"",left:"",top:""}),this._trigger(a?"visible":"hidden")},this),m.effect===z||r===z?(g[k](),j()):d.isFunction(m.effect)?(g.stop(1,1),m.effect.call(g,this),g.queue("fx",function(a){j(),a()})):g.fadeTo(90,a?1:0,j),a&&m.target.trigger("qtip-"+this.id+"-inactive"),this))},u.show=function(a){return this.toggle(y,a)},u.hide=function(a){return this.toggle(z,a)},u.focus=function(a){if(!this.rendered||this.destroyed)return this;var b=d(N),c=this.tooltip,e=parseInt(c[0].style.zIndex,10),f=t.zindex+b.length;return c.hasClass(R)||this._trigger("focus",[f],a)&&(e!==f&&(b.each(function(){this.style.zIndex>e&&(this.style.zIndex=this.style.zIndex-1)}),b.filter("."+R).qtip("blur",a)),c.addClass(R)[0].style.zIndex=f),this},u.blur=function(a){return!this.rendered||this.destroyed?this:(this.tooltip.removeClass(R),this._trigger("blur",[this.tooltip.css("zIndex")],a),this)},u.disable=function(a){return this.destroyed?this:("toggle"===a?a=!(this.rendered?this.tooltip.hasClass(T):this.disabled):"boolean"!=typeof a&&(a=y),this.rendered&&this.tooltip.toggleClass(T,a).attr("aria-disabled",a),this.disabled=!!a,this)},u.enable=function(){return this.disable(z)},u._createButton=function(){var a=this,b=this.elements,c=b.tooltip,e=this.options.content.button,f="string"==typeof e,g=f?e:"Close tooltip";b.button&&b.button.remove(),b.button=e.jquery?e:d("",{"class":"qtip-close "+(this.options.style.widget?"":J+"-icon"),title:g,"aria-label":g}).prepend(d("",{"class":"ui-icon ui-icon-close",html:"×"})),b.button.appendTo(b.titlebar||c).attr("role","button").click(function(b){return c.hasClass(T)||a.hide(b),z})},u._updateButton=function(a){if(!this.rendered)return z;var b=this.elements.button;a?this._createButton():b.remove()},u._setWidget=function(){var a=this.options.style.widget,b=this.elements,c=b.tooltip,d=c.hasClass(T);c.removeClass(T),T=a?"ui-state-disabled":"qtip-disabled",c.toggleClass(T,d),c.toggleClass("ui-helper-reset "+k(),a).toggleClass(Q,this.options.style.def&&!a),b.content&&b.content.toggleClass(k("content"),a),b.titlebar&&b.titlebar.toggleClass(k("header"),a),b.button&&b.button.toggleClass(J+"-icon",!a)},u._storeMouse=function(a){(this.mouse=l(a)).type="mousemove"},u._bind=function(a,b,c,e,f){var g="."+this._id+(e?"-"+e:"");b.length&&d(a).bind((b.split?b:b.join(g+" "))+g,d.proxy(c,f||this))},u._unbind=function(a,b){d(a).unbind("."+this._id+(b?"-"+b:""))};var $="."+J;d(function(){r(N,["mouseenter","mouseleave"],function(a){var b="mouseenter"===a.type,c=d(a.currentTarget),e=d(a.relatedTarget||a.target),f=this.options;b?(this.focus(a),c.hasClass(P)&&!c.hasClass(T)&&clearTimeout(this.timers.hide)):"mouse"===f.position.target&&f.hide.event&&f.show.target&&!e.closest(f.show.target[0]).length&&this.hide(a),c.toggleClass(S,b)}),r("["+L+"]",O,p)}),u._trigger=function(a,b,c){var e=d.Event("tooltip"+a);return e.originalEvent=c&&d.extend({},c)||this.cache.event||A,this.triggering=a,this.tooltip.trigger(e,[this].concat(b||[])),this.triggering=z,!e.isDefaultPrevented()},u._bindEvents=function(a,b,c,e,f,g){if(e.add(c).length===e.length){var h=[];b=d.map(b,function(b){var c=d.inArray(b,a);return c>-1?(h.push(a.splice(c,1)[0]),void 0):b}),h.length&&this._bind(c,h,function(a){var b=this.rendered?this.tooltip[0].offsetWidth>0:!1;(b?g:f).call(this,a)})}this._bind(c,a,f),this._bind(e,b,g)},u._assignInitialEvents=function(a){function b(a){return this.disabled||this.destroyed?z:(this.cache.event=l(a),this.cache.target=a?d(a.target):[c],clearTimeout(this.timers.show),this.timers.show=m.call(this,function(){this.render("object"==typeof a||e.show.ready)},e.show.delay),void 0)}var e=this.options,f=e.show.target,g=e.hide.target,h=e.show.event?d.trim(""+e.show.event).split(" "):[],i=e.hide.event?d.trim(""+e.hide.event).split(" "):[];/mouse(over|enter)/i.test(e.show.event)&&!/mouse(out|leave)/i.test(e.hide.event)&&i.push("mouseleave"),this._bind(f,"mousemove",function(a){this._storeMouse(a),this.cache.onTarget=y}),this._bindEvents(h,i,f,g,b,function(){clearTimeout(this.timers.show)}),(e.show.ready||e.prerender)&&b.call(this,a)},u._assignEvents=function(){var c=this,e=this.options,f=e.position,g=this.tooltip,h=e.show.target,i=e.hide.target,j=f.container,k=f.viewport,l=d(b),m=(d(b.body),d(a)),r=e.show.event?d.trim(""+e.show.event).split(" "):[],s=e.hide.event?d.trim(""+e.hide.event).split(" "):[];d.each(e.events,function(a,b){c._bind(g,"toggle"===a?["tooltipshow","tooltiphide"]:["tooltip"+a],b,null,g)}),/mouse(out|leave)/i.test(e.hide.event)&&"window"===e.hide.leave&&this._bind(l,["mouseout","blur"],function(a){/select|option/.test(a.target.nodeName)||a.relatedTarget||this.hide(a)}),e.hide.fixed?i=i.add(g.addClass(P)):/mouse(over|enter)/i.test(e.show.event)&&this._bind(i,"mouseleave",function(){clearTimeout(this.timers.show)}),(""+e.hide.event).indexOf("unfocus")>-1&&this._bind(j.closest("html"),["mousedown","touchstart"],function(a){var b=d(a.target),c=this.rendered&&!this.tooltip.hasClass(T)&&this.tooltip[0].offsetWidth>0,e=b.parents(N).filter(this.tooltip[0]).length>0;b[0]===this.target[0]||b[0]===this.tooltip[0]||e||this.target.has(b[0]).length||!c||this.hide(a)}),"number"==typeof e.hide.inactive&&(this._bind(h,"qtip-"+this.id+"-inactive",p),this._bind(i.add(g),t.inactiveEvents,p,"-inactive")),this._bindEvents(r,s,h,i,n,o),this._bind(h.add(g),"mousemove",function(a){if("number"==typeof e.hide.distance){var b=this.cache.origin||{},c=this.options.hide.distance,d=Math.abs;(d(a.pageX-b.pageX)>=c||d(a.pageY-b.pageY)>=c)&&this.hide(a)}this._storeMouse(a)}),"mouse"===f.target&&f.adjust.mouse&&(e.hide.event&&this._bind(h,["mouseenter","mouseleave"],function(a){this.cache.onTarget="mouseenter"===a.type}),this._bind(l,"mousemove",function(a){this.rendered&&this.cache.onTarget&&!this.tooltip.hasClass(T)&&this.tooltip[0].offsetWidth>0&&this.reposition(a)})),(f.adjust.resize||k.length)&&this._bind(d.event.special.resize?k:m,"resize",q),f.adjust.scroll&&this._bind(m.add(f.container),"scroll",q)},u._unassignEvents=function(){var c=[this.options.show.target[0],this.options.hide.target[0],this.rendered&&this.tooltip[0],this.options.position.container[0],this.options.position.viewport[0],this.options.position.container.closest("html")[0],a,b];this._unbind(d([]).pushStack(d.grep(c,function(a){return"object"==typeof a})))},t=d.fn.qtip=function(a,b,e){var f=(""+a).toLowerCase(),g=A,i=d.makeArray(arguments).slice(1),j=i[i.length-1],k=this[0]?d.data(this[0],J):A;return!arguments.length&&k||"api"===f?k:"string"==typeof a?(this.each(function(){var a=d.data(this,J);if(!a)return y;if(j&&j.timeStamp&&(a.cache.event=j),!b||"option"!==f&&"options"!==f)a[f]&&a[f].apply(a,i);else{if(e===c&&!d.isPlainObject(b))return g=a.get(b),z;a.set(b,e)}}),g!==A?g:this):"object"!=typeof a&&arguments.length?void 0:(k=h(d.extend(y,{},a)),this.each(function(a){var b,c;return c=d.isArray(k.id)?k.id[a]:k.id,c=!c||c===z||c.length<1||t.api[c]?t.nextid++:c,b=s(d(this),c,k),b===z?y:(t.api[c]=b,d.each(I,function(){"initialize"===this.initialize&&this(b)}),b._assignInitialEvents(j),void 0)}))},d.qtip=e,t.api={},d.each({attr:function(a,b){if(this.length){var c=this[0],e="title",f=d.data(c,"qtip");if(a===e&&f&&"object"==typeof f&&f.options.suppress)return arguments.length<2?d.attr(c,V):(f&&f.options.content.attr===e&&f.cache.attr&&f.set("content.text",b),this.attr(V,b))}return d.fn["attr"+U].apply(this,arguments)},clone:function(a){var b=(d([]),d.fn["clone"+U].apply(this,arguments));return a||b.filter("["+V+"]").attr("title",function(){return d.attr(this,V)}).removeAttr(V),b}},function(a,b){if(!b||d.fn[a+U])return y;var c=d.fn[a+U]=d.fn[a];d.fn[a]=function(){return b.apply(this,arguments)||c.apply(this,arguments)}}),d.ui||(d["cleanData"+U]=d.cleanData,d.cleanData=function(a){for(var b,c=0;(b=d(a[c])).length;c++)if(b.attr(K))try{b.triggerHandler("removeqtip")}catch(e){}d["cleanData"+U].apply(this,arguments)}),t.version="2.2.0",t.nextid=0,t.inactiveEvents=O,t.zindex=15e3,t.defaults={prerender:z,id:z,overwrite:y,suppress:y,content:{text:y,attr:"title",title:z,button:z},position:{my:"top left",at:"bottom right",target:z,container:z,viewport:z,adjust:{x:0,y:0,mouse:y,scroll:y,resize:y,method:"flipinvert flipinvert"},effect:function(a,b){d(this).animate(b,{duration:200,queue:z})}},show:{target:z,event:"mouseenter",effect:y,delay:90,solo:z,ready:z,autofocus:z},hide:{target:z,event:"mouseleave",effect:y,delay:0,fixed:z,inactive:z,leave:"window",distance:z},style:{classes:"",widget:z,width:z,height:z,def:y},events:{render:A,move:A,show:A,hide:A,toggle:A,visible:A,hidden:A,focus:A,blur:A}}})}(window,document);} -//# sourceMappingURL=http://cdnjs.cloudflare.com/ajax/libs/qtip2/2.2.0//var/www/qtip2/build/tmp/tmp-9404qaj6jps/jquery.qtip.min.map \ No newline at end of file diff --git a/library/admin/ReduxCore/assets/js/vendor/redux.select2.sortable.js b/library/admin/ReduxCore/assets/js/vendor/redux.select2.sortable.js deleted file mode 100644 index 896c1adc..00000000 --- a/library/admin/ReduxCore/assets/js/vendor/redux.select2.sortable.js +++ /dev/null @@ -1,152 +0,0 @@ -/** - * jQuery Select2 Sortable - * - enable select2 to be sortable via normal select element - * - * author : Vafour - * modified : Kevin Provance (kprovance) - * inspired by : jQuery Chosen Sortable (https://github.com/mrhenry/jquery-chosen-sortable) - * License : GPL - */ - -(function ($) { - $.fn.extend({ - select2SortableOrder: function () { - var $this = this.filter('[multiple]'); - - $this.each(function () { - var $select = $(this); - - // skip elements not select2-ed - if (typeof ($select.data('select2')) !== 'object') { - return false; - } - - var $select2 = $select.siblings('.select2-container'); - var sorted; - - // Opt group names - var optArr = []; - - $select.find('optgroup').each(function(idx, val) { - optArr.push (val); - }); - - $select.find('option').each(function(idx, val) { - var groupName = $(this).parent('optgroup').prop('label'); - var optVal = this; - - if (groupName === undefined) { - if (this.value !== '' && !this.selected) { - optArr.push (optVal); - } - } - }); - - sorted = $($select2.find('.select2-choices li[class!="select2-search-field"]').map(function () { - if (!this) { - return undefined; - } - - if($(this).data('select2Data') != undefined){ - var id = $(this).data('select2Data').id; - return $select.find('option[value="' + id + '"]')[0]; - } - - - //var id = $(this).data('select2Data').id; - - //return $select.find('option[value="' + id + '"]')[0]; - })); - - sorted.push.apply(sorted, optArr); - - $select.children().remove(); - $select.append(sorted); - }); - - return $this; - }, - - select2Sortable: function () { - var args = Array.prototype.slice.call(arguments, 0); - $this = this.filter('[multiple]'), - validMethods = ['destroy']; - - if (args.length === 0 || typeof (args[0]) === 'object') { - var defaultOptions = { - bindOrder: 'formSubmit', // or sortableStop - sortableOptions: { - placeholder: 'ui-state-highlight', - items: 'li:not(.select2-search-field)', - tolerance: 'pointer' - } - }; - - var options = $.extend(defaultOptions, args[0]); - - // Init select2 only if not already initialized to prevent select2 configuration loss - if (typeof ($this.data('select2')) !== 'object') { - $this.select2(); - } - - $this.each(function () { - var $select = $(this) - var $select2choices = $select.siblings('.select2-container').find('.select2-choices'); - - // Init jQuery UI Sortable - $select2choices.sortable(options.sortableOptions); - - switch (options.bindOrder) { - case 'sortableStop': - // apply options ordering in sortstop event - $select2choices.on("sortstop.select2sortable", function (event, ui) { - $select.select2SortableOrder(); - }); - - $select.on('change', function (e) { - $(this).select2SortableOrder(); - }); - break; - - default: - // apply options ordering in form submit - $select.closest('form').unbind('submit.select2sortable').on('submit.select2sortable', function () { - $select.select2SortableOrder(); - }); - break; - } - }); - } - else if (typeof (args[0] === 'string')) { - if ($.inArray(args[0], validMethods) == -1) { - throw "Unknown method: " + args[0]; - } - - if (args[0] === 'destroy') { - $this.select2SortableDestroy(); - } - } - - return $this; - }, - - select2SortableDestroy: function () { - var $this = this.filter('[multiple]'); - $this.each(function () { - var $select = $(this) - var $select2choices = $select.parent().find('.select2-choices'); - - // unbind form submit event - $select.closest('form').unbind('submit.select2sortable'); - - // unbind sortstop event - $select2choices.unbind("sortstop.select2sortable"); - - // destroy select2Sortable - $select2choices.sortable('destroy'); - }); - - return $this; - } - }); -}(jQuery)); \ No newline at end of file diff --git a/library/admin/ReduxCore/assets/js/vendor/redux.select2.sortable.min.js b/library/admin/ReduxCore/assets/js/vendor/redux.select2.sortable.min.js deleted file mode 100644 index 5ac74dac..00000000 --- a/library/admin/ReduxCore/assets/js/vendor/redux.select2.sortable.min.js +++ /dev/null @@ -1 +0,0 @@ -!function(a){a.fn.extend({select2SortableOrder:function(){var b=this.filter("[multiple]");return b.each(function(){var b=a(this);if("object"!=typeof b.data("select2"))return!1;var c,d=b.siblings(".select2-container"),e=[];b.find("optgroup").each(function(a,b){e.push(b)}),b.find("option").each(function(b,c){var d=a(this).parent("optgroup").prop("label"),f=this;void 0===d&&(""===this.value||this.selected||e.push(f))}),c=a(d.find('.select2-choices li[class!="select2-search-field"]').map(function(){if(!this)return void 0;if(void 0!=a(this).data("select2Data")){var c=a(this).data("select2Data").id;return b.find('option[value="'+c+'"]')[0]}})),c.push.apply(c,e),b.children().remove(),b.append(c)}),b},select2Sortable:function(){var b=Array.prototype.slice.call(arguments,0);if($this=this.filter("[multiple]"),validMethods=["destroy"],0===b.length||"object"==typeof b[0]){var c={bindOrder:"formSubmit",sortableOptions:{placeholder:"ui-state-highlight",items:"li:not(.select2-search-field)",tolerance:"pointer"}},d=a.extend(c,b[0]);"object"!=typeof $this.data("select2")&&$this.select2(),$this.each(function(){var b=a(this),c=b.siblings(".select2-container").find(".select2-choices");switch(c.sortable(d.sortableOptions),d.bindOrder){case"sortableStop":c.on("sortstop.select2sortable",function(a,c){b.select2SortableOrder()}),b.on("change",function(b){a(this).select2SortableOrder()});break;default:b.closest("form").unbind("submit.select2sortable").on("submit.select2sortable",function(){b.select2SortableOrder()})}})}else{if(-1==a.inArray(b[0],validMethods))throw"Unknown method: "+b[0];"destroy"===b[0]&&$this.select2SortableDestroy()}return $this},select2SortableDestroy:function(){var b=this.filter("[multiple]");return b.each(function(){var b=a(this),c=b.parent().find(".select2-choices");b.closest("form").unbind("submit.select2sortable"),c.unbind("sortstop.select2sortable"),c.sortable("destroy")}),b}})}(jQuery); \ No newline at end of file diff --git a/library/admin/ReduxCore/assets/js/vendor/spectrum/redux-spectrum.js b/library/admin/ReduxCore/assets/js/vendor/spectrum/redux-spectrum.js deleted file mode 100644 index 5a303618..00000000 --- a/library/admin/ReduxCore/assets/js/vendor/spectrum/redux-spectrum.js +++ /dev/null @@ -1,2088 +0,0 @@ -// Spectrum Colorpicker v1.3.3 -// https://github.com/bgrins/spectrum -// Author: Brian Grinstead -// License: MIT - -(function (window, $, undefined) { - var defaultOpts = { - - // Callbacks - beforeShow: noop, - move: noop, - change: noop, - show: noop, - hide: noop, - - // Options - color: false, - flat: false, - showInput: false, - allowEmpty: false, - showButtons: true, - clickoutFiresChange: false, - showInitial: false, - showPalette: false, - showPaletteOnly: false, - showSelectionPalette: true, - localStorageKey: false, - appendTo: "body", - maxSelectionSize: 7, - cancelText: "cancel", - chooseText: "choose", - clearText: "Clear Color Selection", - preferredFormat: false, - className: "", // Deprecated - use containerClassName and replacerClassName instead. - containerClassName: "", - replacerClassName: "", - showAlpha: false, - theme: "sp-light", - palette: [["#ffffff", "#000000", "#ff0000", "#ff8000", "#ffff00", "#008000", "#0000ff", "#4b0082", "#9400d3"]], - selectionPalette: [], - disabled: false, - inputText: '' - }, - spectrums = [], - IE = !!/msie/i.exec( window.navigator.userAgent ), - rgbaSupport = (function() { - function contains( str, substr ) { - return !!~('' + str).indexOf(substr); - } - - var elem = document.createElement('div'); - var style = elem.style; - style.cssText = 'background-color:rgba(0,0,0,.5)'; - return contains(style.backgroundColor, 'rgba') || contains(style.backgroundColor, 'hsla'); - })(), - inputTypeColorSupport = (function() { - var colorInput = $("")[0]; - return colorInput.type === "color" && colorInput.value !== "#ffffff"; - })(), - replaceInput = [ - "
    ", - "
    ", - "
    ", - //"
    " + opts.inputText + "
    ", - "
    " - ].join(''), - markup = (function () { - - // IE does not support gradients with multiple stops, so we need to simulate - // that for the rainbow slider with 8 divs that each have a single gradient - var gradientFix = ""; - if (IE) { - for (var i = 1; i <= 6; i++) { - gradientFix += "
    "; - } - } - - return [ - "
    " - ].join(""); - })(); - - function paletteTemplate (p, color, className, tooltipFormat) { - var html = []; - for (var i = 0; i < p.length; i++) { - var current = p[i]; - if(current) { - var tiny = tinycolor(current); - var c = tiny.toHsl().l < 0.5 ? "sp-thumb-el sp-thumb-dark" : "sp-thumb-el sp-thumb-light"; - c += (tinycolor.equals(color, current)) ? " sp-thumb-active" : ""; - - var formattedString = tiny.toString(tooltipFormat || "rgb"); - var swatchStyle = rgbaSupport ? ("background-color:" + tiny.toRgbString()) : "filter:" + tiny.toFilter(); - html.push(''); - } else { - var cls = 'sp-clear-display'; - html.push(''); - } - } - return "
    " + html.join('') + "
    "; - } - - function hideAll() { - for (var i = 0; i < spectrums.length; i++) { - if (spectrums[i]) { - spectrums[i].hide(); - } - } - } - - function instanceOptions(o, callbackContext) { - var opts = $.extend({}, defaultOpts, o); - opts.callbacks = { - 'move': bind(opts.move, callbackContext), - 'change': bind(opts.change, callbackContext), - 'show': bind(opts.show, callbackContext), - 'hide': bind(opts.hide, callbackContext), - 'beforeShow': bind(opts.beforeShow, callbackContext) - }; - - return opts; - } - - function spectrum(element, o) { - - var opts = instanceOptions(o, element), - flat = opts.flat, - showSelectionPalette = opts.showSelectionPalette, - localStorageKey = opts.localStorageKey, - theme = opts.theme, - callbacks = opts.callbacks, - resize = throttle(reflow, 10), - visible = false, - dragWidth = 0, - dragHeight = 0, - dragHelperHeight = 0, - slideHeight = 0, - slideWidth = 0, - alphaWidth = 0, - alphaSlideHelperWidth = 0, - slideHelperHeight = 0, - currentHue = 0, - currentSaturation = 0, - currentValue = 0, - currentAlpha = 1, - palette = [], - paletteArray = [], - paletteLookup = {}, - selectionPalette = opts.selectionPalette.slice(0), - maxSelectionSize = opts.maxSelectionSize, - draggingClass = "sp-dragging", - inputText = opts.inputText, - shiftMovementDirection = null; - - var doc = element.ownerDocument, - body = doc.body, - boundElement = $(element), - disabled = false, - container = $(markup, doc).addClass(theme), - dragger = container.find(".sp-color"), - dragHelper = container.find(".sp-dragger"), - slider = container.find(".sp-hue"), - slideHelper = container.find(".sp-slider"), - alphaSliderInner = container.find(".sp-alpha-inner"), - alphaSlider = container.find(".sp-alpha"), - alphaSlideHelper = container.find(".sp-alpha-handle"), - textInput = container.find(".sp-input"), - paletteContainer = container.find(".sp-palette"), - initialColorContainer = container.find(".sp-initial"), - cancelButton = container.find(".sp-cancel"), - clearButton = container.find(".sp-clear"), - chooseButton = container.find(".sp-choose"), - isInput = boundElement.is("input"), - isInputTypeColor = isInput && inputTypeColorSupport && boundElement.attr("type") === "color", - shouldReplace = isInput && !flat, - replacer = (shouldReplace) ? $(replaceInput).addClass(theme).addClass(opts.className).addClass(opts.replacerClassName) : $([]), - offsetElement = (shouldReplace) ? replacer : boundElement, - previewElement = replacer.find(".sp-preview-inner"), - initialColor = opts.color || (isInput && boundElement.val()), - colorOnShow = false, - preferredFormat = opts.preferredFormat, - currentPreferredFormat = preferredFormat, - clickoutFiresChange = !opts.showButtons || opts.clickoutFiresChange, - isEmpty = !initialColor, - allowEmpty = opts.allowEmpty && !isInputTypeColor; - - if (inputText !== '') { - var x = $(offsetElement).find('div.sp-dd'); - x.text(inputText); - } - - function applyOptions() { - - if (opts.showPaletteOnly) { - opts.showPalette = true; - } - - if (opts.palette) { - palette = opts.palette.slice(0); - paletteArray = $.isArray(palette[0]) ? palette : [palette]; - paletteLookup = {}; - for (var i = 0; i < paletteArray.length; i++) { - for (var j = 0; j < paletteArray[i].length; j++) { - var rgb = tinycolor(paletteArray[i][j]).toRgbString(); - paletteLookup[rgb] = true; - } - } - } - - container.toggleClass("sp-flat", flat); - container.toggleClass("sp-input-disabled", !opts.showInput); - container.toggleClass("sp-alpha-enabled", opts.showAlpha); - container.toggleClass("sp-clear-enabled", allowEmpty); - container.toggleClass("sp-buttons-disabled", !opts.showButtons); - container.toggleClass("sp-palette-disabled", !opts.showPalette); - container.toggleClass("sp-palette-only", opts.showPaletteOnly); - container.toggleClass("sp-initial-disabled", !opts.showInitial); - container.addClass(opts.className).addClass(opts.containerClassName); - - reflow(); - } - - function initialize() { - - if (IE) { - container.find("*:not(input)").attr("unselectable", "on"); - } - - applyOptions(); - - if (shouldReplace) { - boundElement.after(replacer).hide(); - } - - if (!allowEmpty) { - clearButton.hide(); - } - - if (flat) { - boundElement.after(container).hide(); - } - else { - - var appendTo = opts.appendTo === "parent" ? boundElement.parent() : $(opts.appendTo); - if (appendTo.length !== 1) { - appendTo = $("body"); - } - - appendTo.append(container); - } - - updateSelectionPaletteFromStorage(); - - offsetElement.bind("click.spectrum touchstart.spectrum", function (e) { - if (!disabled) { - toggle(); - } - - e.stopPropagation(); - - if (!$(e.target).is("input")) { - e.preventDefault(); - } - }); - - if(boundElement.is(":disabled") || (opts.disabled === true)) { - disable(); - } - - // Prevent clicks from bubbling up to document. This would cause it to be hidden. - container.click(stopPropagation); - - // Handle user typed input - textInput.change(setFromTextInput); - textInput.bind("paste", function () { - setTimeout(setFromTextInput, 1); - }); - textInput.keydown(function (e) { if (e.keyCode == 13) { setFromTextInput(); } }); - - cancelButton.text(opts.cancelText); - cancelButton.bind("click.spectrum", function (e) { - e.stopPropagation(); - e.preventDefault(); - hide("cancel"); - }); - - clearButton.attr("title", opts.clearText); - clearButton.bind("click.spectrum", function (e) { - e.stopPropagation(); - e.preventDefault(); - isEmpty = true; - move(); - - if(flat) { - //for the flat style, this is a change event - updateOriginalInput(true); - } - }); - - chooseButton.text(opts.chooseText); - chooseButton.bind("click.spectrum", function (e) { - e.stopPropagation(); - e.preventDefault(); - - if (isValid()) { - updateOriginalInput(true); - hide(); - } - }); - - draggable(alphaSlider, function (dragX, dragY, e) { - currentAlpha = (dragX / alphaWidth); - isEmpty = false; - if (e.shiftKey) { - currentAlpha = Math.round(currentAlpha * 10) / 10; - } - - move(); - }, dragStart, dragStop); - - draggable(slider, function (dragX, dragY) { - currentHue = parseFloat(dragY / slideHeight); - isEmpty = false; - if (!opts.showAlpha) { - currentAlpha = 1; - } - move(); - }, dragStart, dragStop); - - draggable(dragger, function (dragX, dragY, e) { - - // shift+drag should snap the movement to either the x or y axis. - if (!e.shiftKey) { - shiftMovementDirection = null; - } - else if (!shiftMovementDirection) { - var oldDragX = currentSaturation * dragWidth; - var oldDragY = dragHeight - (currentValue * dragHeight); - var furtherFromX = Math.abs(dragX - oldDragX) > Math.abs(dragY - oldDragY); - - shiftMovementDirection = furtherFromX ? "x" : "y"; - } - - var setSaturation = !shiftMovementDirection || shiftMovementDirection === "x"; - var setValue = !shiftMovementDirection || shiftMovementDirection === "y"; - - if (setSaturation) { - currentSaturation = parseFloat(dragX / dragWidth); - } - if (setValue) { - currentValue = parseFloat((dragHeight - dragY) / dragHeight); - } - - isEmpty = false; - if (!opts.showAlpha) { - currentAlpha = 1; - } - - move(); - - }, dragStart, dragStop); - - if (!!initialColor) { - set(initialColor); - - // In case color was black - update the preview UI and set the format - // since the set function will not run (default color is black). - updateUI(); - currentPreferredFormat = preferredFormat || tinycolor(initialColor).format; - - addColorToSelectionPalette(initialColor); - } - else { - updateUI(); - } - - if (flat) { - show(); - } - - function palletElementClick(e) { - if (e.data && e.data.ignore) { - set($(this).data("color")); - move(); - } - else { - set($(this).data("color")); - move(); - updateOriginalInput(true); - hide(); - } - - return false; - } - - var paletteEvent = IE ? "mousedown.spectrum" : "click.spectrum touchstart.spectrum"; - paletteContainer.delegate(".sp-thumb-el", paletteEvent, palletElementClick); - initialColorContainer.delegate(".sp-thumb-el:nth-child(1)", paletteEvent, { ignore: true }, palletElementClick); - } - - function updateSelectionPaletteFromStorage() { - - if (localStorageKey && window.localStorage) { - - // Migrate old palettes over to new format. May want to remove this eventually. - try { - var oldPalette = window.localStorage[localStorageKey].split(",#"); - if (oldPalette.length > 1) { - delete window.localStorage[localStorageKey]; - $.each(oldPalette, function(i, c) { - addColorToSelectionPalette(c); - }); - } - } - catch(e) { } - - try { - selectionPalette = window.localStorage[localStorageKey].split(";"); - } - catch (e) { } - } - } - - function addColorToSelectionPalette(color) { - if (showSelectionPalette) { - var rgb = tinycolor(color).toRgbString(); - if (!paletteLookup[rgb] && $.inArray(rgb, selectionPalette) === -1) { - selectionPalette.push(rgb); - while(selectionPalette.length > maxSelectionSize) { - selectionPalette.shift(); - } - } - - if (localStorageKey && window.localStorage) { - try { - window.localStorage[localStorageKey] = selectionPalette.join(";"); - } - catch(e) { } - } - } - } - - function getUniqueSelectionPalette() { - var unique = []; - if (opts.showPalette) { - for (i = 0; i < selectionPalette.length; i++) { - var rgb = tinycolor(selectionPalette[i]).toRgbString(); - - if (!paletteLookup[rgb]) { - unique.push(selectionPalette[i]); - } - } - } - - return unique.reverse().slice(0, opts.maxSelectionSize); - } - - function drawPalette() { - - var currentColor = get(); - - var html = $.map(paletteArray, function (palette, i) { - return paletteTemplate(palette, currentColor, "sp-palette-row sp-palette-row-" + i, opts.preferredFormat); - }); - - updateSelectionPaletteFromStorage(); - - if (selectionPalette) { - html.push(paletteTemplate(getUniqueSelectionPalette(), currentColor, "sp-palette-row sp-palette-row-selection", opts.preferredFormat)); - } - - paletteContainer.html(html.join("")); - } - - function drawInitial() { - if (opts.showInitial) { - var initial = colorOnShow; - var current = get(); - initialColorContainer.html(paletteTemplate([initial, current], current, "sp-palette-row-initial", opts.preferredFormat)); - } - } - - function dragStart() { - if (dragHeight <= 0 || dragWidth <= 0 || slideHeight <= 0) { - reflow(); - } - container.addClass(draggingClass); - shiftMovementDirection = null; - boundElement.trigger('dragstart.spectrum', [ get() ]); - } - - function dragStop() { - container.removeClass(draggingClass); - boundElement.trigger('dragstop.spectrum', [ get() ]); - } - - function setFromTextInput() { - - var value = textInput.val(); - - if ((value === null || value === "") && allowEmpty) { - set(null); - updateOriginalInput(true); - } - else { - var tiny = tinycolor(value); - if (tiny.ok) { - set(tiny); - updateOriginalInput(true); - } - else { - textInput.addClass("sp-validation-error"); - } - } - } - - function toggle() { - if (visible) { - hide(); - } - else { - show(); - } - } - - function show() { - var event = $.Event('beforeShow.spectrum'); - - if (visible) { - reflow(); - return; - } - - boundElement.trigger(event, [ get() ]); - - if (callbacks.beforeShow(get()) === false || event.isDefaultPrevented()) { - return; - } - - hideAll(); - visible = true; - - $(doc).bind("click.spectrum", hide); - $(window).bind("resize.spectrum", resize); - replacer.addClass("sp-active"); - container.removeClass("sp-hidden"); - - reflow(); - updateUI(); - - colorOnShow = get(); - - drawInitial(); - callbacks.show(colorOnShow); - boundElement.trigger('show.spectrum', [ colorOnShow ]); - } - - function hide(e) { - - // Return on right click - if (e && e.type == "click" && e.button == 2) { return; } - - // Return if hiding is unnecessary - if (!visible || flat) { return; } - visible = false; - - $(doc).unbind("click.spectrum", hide); - $(window).unbind("resize.spectrum", resize); - - replacer.removeClass("sp-active"); - container.addClass("sp-hidden"); - - var colorHasChanged = !tinycolor.equals(get(), colorOnShow); - - if (colorHasChanged) { - if (clickoutFiresChange && e !== "cancel") { - updateOriginalInput(true); - } - else { - revert(); - } - } - - callbacks.hide(get()); - boundElement.trigger('hide.spectrum', [ get() ]); - } - - function revert() { - set(colorOnShow, true); - } - - function set(color, ignoreFormatChange) { - if (tinycolor.equals(color, get())) { - // Update UI just in case a validation error needs - // to be cleared. - updateUI(); - return; - } - - var newColor, newHsv; - if (!color && allowEmpty) { - isEmpty = true; - } else { - isEmpty = false; - newColor = tinycolor(color); - newHsv = newColor.toHsv(); - - currentHue = (newHsv.h % 360) / 360; - currentSaturation = newHsv.s; - currentValue = newHsv.v; - currentAlpha = newHsv.a; - } - updateUI(); - - if (newColor && newColor.ok && !ignoreFormatChange) { - currentPreferredFormat = preferredFormat || newColor.format; - } - } - - function get(opts) { - opts = opts || { }; - - if (allowEmpty && isEmpty) { - return null; - } - - return tinycolor.fromRatio({ - h: currentHue, - s: currentSaturation, - v: currentValue, - a: Math.round(currentAlpha * 100) / 100 - }, { format: opts.format || currentPreferredFormat }); - } - - function isValid() { - return !textInput.hasClass("sp-validation-error"); - } - - function move() { - updateUI(); - - callbacks.move(get()); - boundElement.trigger('move.spectrum', [ get() ]); - } - - function updateUI() { - - textInput.removeClass("sp-validation-error"); - - updateHelperLocations(); - - // Update dragger background color (gradients take care of saturation and value). - var flatColor = tinycolor.fromRatio({ h: currentHue, s: 1, v: 1 }); - dragger.css("background-color", flatColor.toHexString()); - - // Get a format that alpha will be included in (hex and names ignore alpha) - var format = currentPreferredFormat; - if (currentAlpha < 1 && !(currentAlpha === 0 && format === "name")) { - if (format === "hex" || format === "hex3" || format === "hex6" || format === "name") { - format = "rgb"; - } - } - - var realColor = get({ format: format }), - displayColor = ''; - - //reset background info for preview element - previewElement.removeClass("sp-clear-display"); - previewElement.css('background-color', 'transparent'); - - if (!realColor && allowEmpty) { - // Update the replaced elements background with icon indicating no color selection - previewElement.addClass("sp-clear-display"); - } - else { - var realHex = realColor.toHexString(), - realRgb = realColor.toRgbString(); - - // Update the replaced elements background color (with actual selected color) - if (rgbaSupport || realColor.alpha === 1) { - previewElement.css("background-color", realRgb); - } - else { - previewElement.css("background-color", "transparent"); - previewElement.css("filter", realColor.toFilter()); - } - - if (opts.showAlpha) { - var rgb = realColor.toRgb(); - rgb.a = 0; - var realAlpha = tinycolor(rgb).toRgbString(); - var gradient = "linear-gradient(left, " + realAlpha + ", " + realHex + ")"; - - if (IE) { - alphaSliderInner.css("filter", tinycolor(realAlpha).toFilter({ gradientType: 1 }, realHex)); - } - else { - alphaSliderInner.css("background", "-webkit-" + gradient); - alphaSliderInner.css("background", "-moz-" + gradient); - alphaSliderInner.css("background", "-ms-" + gradient); - // Use current syntax gradient on unprefixed property. - alphaSliderInner.css("background", - "linear-gradient(to right, " + realAlpha + ", " + realHex + ")"); - } - } - - displayColor = realColor.toString(format); - } - - // Update the text entry input as it changes happen - if (opts.showInput) { - textInput.val(displayColor); - } - - if (opts.showPalette) { - drawPalette(); - } - - drawInitial(); - } - - function updateHelperLocations() { - var s = currentSaturation; - var v = currentValue; - - if(allowEmpty && isEmpty) { - //if selected color is empty, hide the helpers - alphaSlideHelper.hide(); - slideHelper.hide(); - dragHelper.hide(); - } - else { - //make sure helpers are visible - alphaSlideHelper.show(); - slideHelper.show(); - dragHelper.show(); - - // Where to show the little circle in that displays your current selected color - var dragX = s * dragWidth; - var dragY = dragHeight - (v * dragHeight); - dragX = Math.max( - -dragHelperHeight, - Math.min(dragWidth - dragHelperHeight, dragX - dragHelperHeight) - ); - dragY = Math.max( - -dragHelperHeight, - Math.min(dragHeight - dragHelperHeight, dragY - dragHelperHeight) - ); - dragHelper.css({ - "top": dragY + "px", - "left": dragX + "px" - }); - - var alphaX = currentAlpha * alphaWidth; - alphaSlideHelper.css({ - "left": (alphaX - (alphaSlideHelperWidth / 2)) + "px" - }); - - // Where to show the bar that displays your current selected hue - var slideY = (currentHue) * slideHeight; - slideHelper.css({ - "top": (slideY - slideHelperHeight) + "px" - }); - } - } - - function updateOriginalInput(fireCallback) { - var color = get(), - displayColor = '', - hasChanged = !tinycolor.equals(color, colorOnShow); - - if (color) { - displayColor = color.toString(currentPreferredFormat); - // Update the selection palette with the current color - addColorToSelectionPalette(color); - } - - if (isInput) { - boundElement.val(displayColor); - } - - colorOnShow = color; - - if (fireCallback && hasChanged) { - callbacks.change(color); - boundElement.trigger('change', [ color ]); - } - } - - function reflow() { - dragWidth = dragger.width(); - dragHeight = dragger.height(); - dragHelperHeight = dragHelper.height(); - slideWidth = slider.width(); - slideHeight = slider.height(); - slideHelperHeight = slideHelper.height(); - alphaWidth = alphaSlider.width(); - alphaSlideHelperWidth = alphaSlideHelper.width(); - - if (!flat) { - container.css("position", "absolute"); - container.offset(getOffset(container, offsetElement)); - } - - updateHelperLocations(); - - if (opts.showPalette) { - drawPalette(); - } - - boundElement.trigger('reflow.spectrum'); - } - - function destroy() { - boundElement.show(); - offsetElement.unbind("click.spectrum touchstart.spectrum"); - container.remove(); - replacer.remove(); - spectrums[spect.id] = null; - } - - function option(optionName, optionValue) { - if (optionName === undefined) { - return $.extend({}, opts); - } - if (optionValue === undefined) { - return opts[optionName]; - } - - opts[optionName] = optionValue; - applyOptions(); - } - - function enable() { - disabled = false; - boundElement.attr("disabled", false); - offsetElement.removeClass("sp-disabled"); - } - - function disable() { - hide(); - disabled = true; - boundElement.attr("disabled", true); - offsetElement.addClass("sp-disabled"); - } - - initialize(); - - var spect = { - show: show, - hide: hide, - toggle: toggle, - reflow: reflow, - option: option, - enable: enable, - disable: disable, - set: function (c) { - set(c); - updateOriginalInput(); - }, - get: get, - destroy: destroy, - container: container - }; - - spect.id = spectrums.push(spect) - 1; - - return spect; - } - - /** - * checkOffset - get the offset below/above and left/right element depending on screen position - * Thanks https://github.com/jquery/jquery-ui/blob/master/ui/jquery.ui.datepicker.js - */ - function getOffset(picker, input) { - var extraY = 0; - var dpWidth = picker.outerWidth(); - var dpHeight = picker.outerHeight(); - var inputHeight = input.outerHeight(); - var doc = picker[0].ownerDocument; - var docElem = doc.documentElement; - var viewWidth = docElem.clientWidth + $(doc).scrollLeft(); - var viewHeight = docElem.clientHeight + $(doc).scrollTop(); - var offset = input.offset(); - offset.top += inputHeight; - - offset.left -= - Math.min(offset.left, (offset.left + dpWidth > viewWidth && viewWidth > dpWidth) ? - Math.abs(offset.left + dpWidth - viewWidth) : 0); - - offset.top -= - Math.min(offset.top, ((offset.top + dpHeight > viewHeight && viewHeight > dpHeight) ? - Math.abs(dpHeight + inputHeight - extraY) : extraY)); - - return offset; - } - - /** - * noop - do nothing - */ - function noop() { - - } - - /** - * stopPropagation - makes the code only doing this a little easier to read in line - */ - function stopPropagation(e) { - e.stopPropagation(); - } - - /** - * Create a function bound to a given object - * Thanks to underscore.js - */ - function bind(func, obj) { - var slice = Array.prototype.slice; - var args = slice.call(arguments, 2); - return function () { - return func.apply(obj, args.concat(slice.call(arguments))); - }; - } - - /** - * Lightweight drag helper. Handles containment within the element, so that - * when dragging, the x is within [0,element.width] and y is within [0,element.height] - */ - function draggable(element, onmove, onstart, onstop) { - onmove = onmove || function () { }; - onstart = onstart || function () { }; - onstop = onstop || function () { }; - var doc = element.ownerDocument || document; - var dragging = false; - var offset = {}; - var maxHeight = 0; - var maxWidth = 0; - var hasTouch = ('ontouchstart' in window); - - var duringDragEvents = {}; - duringDragEvents["selectstart"] = prevent; - duringDragEvents["dragstart"] = prevent; - duringDragEvents["touchmove mousemove"] = move; - duringDragEvents["touchend mouseup"] = stop; - - function prevent(e) { - if (e.stopPropagation) { - e.stopPropagation(); - } - if (e.preventDefault) { - e.preventDefault(); - } - e.returnValue = false; - } - - function move(e) { - if (dragging) { - // Mouseup happened outside of window - if (IE && document.documentMode < 9 && !e.button) { - return stop(); - } - - var touches = e.originalEvent.touches; - var pageX = touches ? touches[0].pageX : e.pageX; - var pageY = touches ? touches[0].pageY : e.pageY; - - var dragX = Math.max(0, Math.min(pageX - offset.left, maxWidth)); - var dragY = Math.max(0, Math.min(pageY - offset.top, maxHeight)); - - if (hasTouch) { - // Stop scrolling in iOS - prevent(e); - } - - onmove.apply(element, [dragX, dragY, e]); - } - } - - function start(e) { - var rightclick = (e.which) ? (e.which == 3) : (e.button == 2); - var touches = e.originalEvent.touches; - - if (!rightclick && !dragging) { - if (onstart.apply(element, arguments) !== false) { - dragging = true; - maxHeight = $(element).height(); - maxWidth = $(element).width(); - offset = $(element).offset(); - - $(doc).bind(duringDragEvents); - $(doc.body).addClass("sp-dragging"); - - if (!hasTouch) { - move(e); - } - - prevent(e); - } - } - } - - function stop() { - if (dragging) { - $(doc).unbind(duringDragEvents); - $(doc.body).removeClass("sp-dragging"); - onstop.apply(element, arguments); - } - dragging = false; - } - - $(element).bind("touchstart mousedown", start); - } - - function throttle(func, wait, debounce) { - var timeout; - return function () { - var context = this, args = arguments; - var throttler = function () { - timeout = null; - func.apply(context, args); - }; - if (debounce) clearTimeout(timeout); - if (debounce || !timeout) timeout = setTimeout(throttler, wait); - }; - } - - function log(){/* jshint -W021 */if(window.console){if(Function.prototype.bind)log=Function.prototype.bind.call(console.log,console);else log=function(){Function.prototype.apply.call(console.log,console,arguments);};log.apply(this,arguments);}} - - /** - * Define a jQuery plugin - */ - var dataID = "spectrum.id"; - $.fn.spectrum = function (opts, extra) { - - if (typeof opts == "string") { - - var returnValue = this; - var args = Array.prototype.slice.call( arguments, 1 ); - - this.each(function () { - var spect = spectrums[$(this).data(dataID)]; - if (spect) { - var method = spect[opts]; - if (!method) { - throw new Error( "Spectrum: no such method: '" + opts + "'" ); - } - - if (opts == "get") { - returnValue = spect.get(); - } - else if (opts == "container") { - returnValue = spect.container; - } - else if (opts == "option") { - returnValue = spect.option.apply(spect, args); - } - else if (opts == "destroy") { - spect.destroy(); - $(this).removeData(dataID); - } - else { - method.apply(spect, args); - } - } - }); - - return returnValue; - } - - // Initializing a new instance of spectrum - return this.spectrum("destroy").each(function () { - var options = $.extend({}, opts, $(this).data()); - var spect = spectrum(this, options); - $(this).data(dataID, spect.id); - }); - }; - - $.fn.spectrum.load = true; - $.fn.spectrum.loadOpts = {}; - $.fn.spectrum.draggable = draggable; - $.fn.spectrum.defaults = defaultOpts; - - $.spectrum = { }; - $.spectrum.localization = { }; - $.spectrum.palettes = { }; - - $.fn.spectrum.processNativeColorInputs = function () { - if (!inputTypeColorSupport) { - $("input[type=color]").spectrum({ - preferredFormat: "hex6" - }); - } - }; - - // TinyColor v0.9.17 - // https://github.com/bgrins/TinyColor - // 2013-08-10, Brian Grinstead, MIT License - - (function() { - - var trimLeft = /^[\s,#]+/, - trimRight = /\s+$/, - tinyCounter = 0, - math = Math, - mathRound = math.round, - mathMin = math.min, - mathMax = math.max, - mathRandom = math.random; - - function tinycolor (color, opts) { - - color = (color) ? color : ''; - opts = opts || { }; - - // If input is already a tinycolor, return itself - if (typeof color == "object" && color.hasOwnProperty("_tc_id")) { - return color; - } - - var rgb = inputToRGB(color); - var r = rgb.r, - g = rgb.g, - b = rgb.b, - a = rgb.a, - roundA = mathRound(100*a) / 100, - format = opts.format || rgb.format; - - // Don't let the range of [0,255] come back in [0,1]. - // Potentially lose a little bit of precision here, but will fix issues where - // .5 gets interpreted as half of the total, instead of half of 1 - // If it was supposed to be 128, this was already taken care of by `inputToRgb` - if (r < 1) { r = mathRound(r); } - if (g < 1) { g = mathRound(g); } - if (b < 1) { b = mathRound(b); } - - return { - ok: rgb.ok, - format: format, - _tc_id: tinyCounter++, - alpha: a, - getAlpha: function() { - return a; - }, - setAlpha: function(value) { - a = boundAlpha(value); - roundA = mathRound(100*a) / 100; - }, - toHsv: function() { - var hsv = rgbToHsv(r, g, b); - return { h: hsv.h * 360, s: hsv.s, v: hsv.v, a: a }; - }, - toHsvString: function() { - var hsv = rgbToHsv(r, g, b); - var h = mathRound(hsv.h * 360), s = mathRound(hsv.s * 100), v = mathRound(hsv.v * 100); - return (a == 1) ? - "hsv(" + h + ", " + s + "%, " + v + "%)" : - "hsva(" + h + ", " + s + "%, " + v + "%, "+ roundA + ")"; - }, - toHsl: function() { - var hsl = rgbToHsl(r, g, b); - return { h: hsl.h * 360, s: hsl.s, l: hsl.l, a: a }; - }, - toHslString: function() { - var hsl = rgbToHsl(r, g, b); - var h = mathRound(hsl.h * 360), s = mathRound(hsl.s * 100), l = mathRound(hsl.l * 100); - return (a == 1) ? - "hsl(" + h + ", " + s + "%, " + l + "%)" : - "hsla(" + h + ", " + s + "%, " + l + "%, "+ roundA + ")"; - }, - toHex: function(allow3Char) { - return rgbToHex(r, g, b, allow3Char); - }, - toHexString: function(allow3Char) { - return '#' + this.toHex(allow3Char); - }, - toHex8: function() { - return rgbaToHex(r, g, b, a); - }, - toHex8String: function() { - return '#' + this.toHex8(); - }, - toRgb: function() { - return { r: mathRound(r), g: mathRound(g), b: mathRound(b), a: a }; - }, - toRgbString: function() { - return (a == 1) ? - "rgb(" + mathRound(r) + ", " + mathRound(g) + ", " + mathRound(b) + ")" : - "rgba(" + mathRound(r) + ", " + mathRound(g) + ", " + mathRound(b) + ", " + roundA + ")"; - }, - toPercentageRgb: function() { - return { r: mathRound(bound01(r, 255) * 100) + "%", g: mathRound(bound01(g, 255) * 100) + "%", b: mathRound(bound01(b, 255) * 100) + "%", a: a }; - }, - toPercentageRgbString: function() { - return (a == 1) ? - "rgb(" + mathRound(bound01(r, 255) * 100) + "%, " + mathRound(bound01(g, 255) * 100) + "%, " + mathRound(bound01(b, 255) * 100) + "%)" : - "rgba(" + mathRound(bound01(r, 255) * 100) + "%, " + mathRound(bound01(g, 255) * 100) + "%, " + mathRound(bound01(b, 255) * 100) + "%, " + roundA + ")"; - }, - toName: function() { - if (a === 0) { - return "transparent"; - } - - return hexNames[rgbToHex(r, g, b, true)] || false; - }, - toFilter: function(secondColor) { - var hex8String = '#' + rgbaToHex(r, g, b, a); - var secondHex8String = hex8String; - var gradientType = opts && opts.gradientType ? "GradientType = 1, " : ""; - - if (secondColor) { - var s = tinycolor(secondColor); - secondHex8String = s.toHex8String(); - } - - return "progid:DXImageTransform.Microsoft.gradient("+gradientType+"startColorstr="+hex8String+",endColorstr="+secondHex8String+")"; - }, - toString: function(format) { - var formatSet = !!format; - format = format || this.format; - - var formattedString = false; - var hasAlphaAndFormatNotSet = !formatSet && a < 1 && a > 0; - var formatWithAlpha = hasAlphaAndFormatNotSet && (format === "hex" || format === "hex6" || format === "hex3" || format === "name"); - - if (format === "rgb") { - formattedString = this.toRgbString(); - } - if (format === "prgb") { - formattedString = this.toPercentageRgbString(); - } - if (format === "hex" || format === "hex6") { - formattedString = this.toHexString(); - } - if (format === "hex3") { - formattedString = this.toHexString(true); - } - if (format === "hex8") { - formattedString = this.toHex8String(); - } - if (format === "name") { - formattedString = this.toName(); - } - if (format === "hsl") { - formattedString = this.toHslString(); - } - if (format === "hsv") { - formattedString = this.toHsvString(); - } - - if (formatWithAlpha) { - return this.toRgbString(); - } - - return formattedString || this.toHexString(); - } - }; - } - - // If input is an object, force 1 into "1.0" to handle ratios properly - // String input requires "1.0" as input, so 1 will be treated as 1 - tinycolor.fromRatio = function(color, opts) { - if (typeof color == "object") { - var newColor = {}; - for (var i in color) { - if (color.hasOwnProperty(i)) { - if (i === "a") { - newColor[i] = color[i]; - } - else { - newColor[i] = convertToPercentage(color[i]); - } - } - } - color = newColor; - } - - return tinycolor(color, opts); - }; - - // Given a string or object, convert that input to RGB - // Possible string inputs: - // - // "red" - // "#f00" or "f00" - // "#ff0000" or "ff0000" - // "#ff000000" or "ff000000" - // "rgb 255 0 0" or "rgb (255, 0, 0)" - // "rgb 1.0 0 0" or "rgb (1, 0, 0)" - // "rgba (255, 0, 0, 1)" or "rgba 255, 0, 0, 1" - // "rgba (1.0, 0, 0, 1)" or "rgba 1.0, 0, 0, 1" - // "hsl(0, 100%, 50%)" or "hsl 0 100% 50%" - // "hsla(0, 100%, 50%, 1)" or "hsla 0 100% 50%, 1" - // "hsv(0, 100%, 100%)" or "hsv 0 100% 100%" - // - function inputToRGB(color) { - - var rgb = { r: 0, g: 0, b: 0 }; - var a = 1; - var ok = false; - var format = false; - - if (typeof color == "string") { - color = stringInputToObject(color); - } - - if (typeof color == "object") { - if (color.hasOwnProperty("r") && color.hasOwnProperty("g") && color.hasOwnProperty("b")) { - rgb = rgbToRgb(color.r, color.g, color.b); - ok = true; - format = String(color.r).substr(-1) === "%" ? "prgb" : "rgb"; - } - else if (color.hasOwnProperty("h") && color.hasOwnProperty("s") && color.hasOwnProperty("v")) { - color.s = convertToPercentage(color.s); - color.v = convertToPercentage(color.v); - rgb = hsvToRgb(color.h, color.s, color.v); - ok = true; - format = "hsv"; - } - else if (color.hasOwnProperty("h") && color.hasOwnProperty("s") && color.hasOwnProperty("l")) { - color.s = convertToPercentage(color.s); - color.l = convertToPercentage(color.l); - rgb = hslToRgb(color.h, color.s, color.l); - ok = true; - format = "hsl"; - } - - if (color.hasOwnProperty("a")) { - a = color.a; - } - } - - a = boundAlpha(a); - - return { - ok: ok, - format: color.format || format, - r: mathMin(255, mathMax(rgb.r, 0)), - g: mathMin(255, mathMax(rgb.g, 0)), - b: mathMin(255, mathMax(rgb.b, 0)), - a: a - }; - } - - - // Conversion Functions - // -------------------- - - // `rgbToHsl`, `rgbToHsv`, `hslToRgb`, `hsvToRgb` modified from: - // - - // `rgbToRgb` - // Handle bounds / percentage checking to conform to CSS color spec - // - // *Assumes:* r, g, b in [0, 255] or [0, 1] - // *Returns:* { r, g, b } in [0, 255] - function rgbToRgb(r, g, b){ - return { - r: bound01(r, 255) * 255, - g: bound01(g, 255) * 255, - b: bound01(b, 255) * 255 - }; - } - - // `rgbToHsl` - // Converts an RGB color value to HSL. - // *Assumes:* r, g, and b are contained in [0, 255] or [0, 1] - // *Returns:* { h, s, l } in [0,1] - function rgbToHsl(r, g, b) { - - r = bound01(r, 255); - g = bound01(g, 255); - b = bound01(b, 255); - - var max = mathMax(r, g, b), min = mathMin(r, g, b); - var h, s, l = (max + min) / 2; - - if(max == min) { - h = s = 0; // achromatic - } - else { - var d = max - min; - s = l > 0.5 ? d / (2 - max - min) : d / (max + min); - switch(max) { - case r: h = (g - b) / d + (g < b ? 6 : 0); break; - case g: h = (b - r) / d + 2; break; - case b: h = (r - g) / d + 4; break; - } - - h /= 6; - } - - return { h: h, s: s, l: l }; - } - - // `hslToRgb` - // Converts an HSL color value to RGB. - // *Assumes:* h is contained in [0, 1] or [0, 360] and s and l are contained [0, 1] or [0, 100] - // *Returns:* { r, g, b } in the set [0, 255] - function hslToRgb(h, s, l) { - var r, g, b; - - h = bound01(h, 360); - s = bound01(s, 100); - l = bound01(l, 100); - - function hue2rgb(p, q, t) { - if(t < 0) t += 1; - if(t > 1) t -= 1; - if(t < 1/6) return p + (q - p) * 6 * t; - if(t < 1/2) return q; - if(t < 2/3) return p + (q - p) * (2/3 - t) * 6; - return p; - } - - if(s === 0) { - r = g = b = l; // achromatic - } - else { - var q = l < 0.5 ? l * (1 + s) : l + s - l * s; - var p = 2 * l - q; - r = hue2rgb(p, q, h + 1/3); - g = hue2rgb(p, q, h); - b = hue2rgb(p, q, h - 1/3); - } - - return { r: r * 255, g: g * 255, b: b * 255 }; - } - - // `rgbToHsv` - // Converts an RGB color value to HSV - // *Assumes:* r, g, and b are contained in the set [0, 255] or [0, 1] - // *Returns:* { h, s, v } in [0,1] - function rgbToHsv(r, g, b) { - - r = bound01(r, 255); - g = bound01(g, 255); - b = bound01(b, 255); - - var max = mathMax(r, g, b), min = mathMin(r, g, b); - var h, s, v = max; - - var d = max - min; - s = max === 0 ? 0 : d / max; - - if(max == min) { - h = 0; // achromatic - } - else { - switch(max) { - case r: h = (g - b) / d + (g < b ? 6 : 0); break; - case g: h = (b - r) / d + 2; break; - case b: h = (r - g) / d + 4; break; - } - h /= 6; - } - return { h: h, s: s, v: v }; - } - - // `hsvToRgb` - // Converts an HSV color value to RGB. - // *Assumes:* h is contained in [0, 1] or [0, 360] and s and v are contained in [0, 1] or [0, 100] - // *Returns:* { r, g, b } in the set [0, 255] - function hsvToRgb(h, s, v) { - - h = bound01(h, 360) * 6; - s = bound01(s, 100); - v = bound01(v, 100); - - var i = math.floor(h), - f = h - i, - p = v * (1 - s), - q = v * (1 - f * s), - t = v * (1 - (1 - f) * s), - mod = i % 6, - r = [v, q, p, p, t, v][mod], - g = [t, v, v, q, p, p][mod], - b = [p, p, t, v, v, q][mod]; - - return { r: r * 255, g: g * 255, b: b * 255 }; - } - - // `rgbToHex` - // Converts an RGB color to hex - // Assumes r, g, and b are contained in the set [0, 255] - // Returns a 3 or 6 character hex - function rgbToHex(r, g, b, allow3Char) { - - var hex = [ - pad2(mathRound(r).toString(16)), - pad2(mathRound(g).toString(16)), - pad2(mathRound(b).toString(16)) - ]; - - // Return a 3 character hex if possible - if (allow3Char && hex[0].charAt(0) == hex[0].charAt(1) && hex[1].charAt(0) == hex[1].charAt(1) && hex[2].charAt(0) == hex[2].charAt(1)) { - return hex[0].charAt(0) + hex[1].charAt(0) + hex[2].charAt(0); - } - - return hex.join(""); - } - // `rgbaToHex` - // Converts an RGBA color plus alpha transparency to hex - // Assumes r, g, b and a are contained in the set [0, 255] - // Returns an 8 character hex - function rgbaToHex(r, g, b, a) { - - var hex = [ - pad2(convertDecimalToHex(a)), - pad2(mathRound(r).toString(16)), - pad2(mathRound(g).toString(16)), - pad2(mathRound(b).toString(16)) - ]; - - return hex.join(""); - } - - // `equals` - // Can be called with any tinycolor input - tinycolor.equals = function (color1, color2) { - if (!color1 || !color2) { return false; } - return tinycolor(color1).toRgbString() == tinycolor(color2).toRgbString(); - }; - tinycolor.random = function() { - return tinycolor.fromRatio({ - r: mathRandom(), - g: mathRandom(), - b: mathRandom() - }); - }; - - - // Modification Functions - // ---------------------- - // Thanks to less.js for some of the basics here - // - - tinycolor.desaturate = function (color, amount) { - amount = (amount === 0) ? 0 : (amount || 10); - var hsl = tinycolor(color).toHsl(); - hsl.s -= amount / 100; - hsl.s = clamp01(hsl.s); - return tinycolor(hsl); - }; - tinycolor.saturate = function (color, amount) { - amount = (amount === 0) ? 0 : (amount || 10); - var hsl = tinycolor(color).toHsl(); - hsl.s += amount / 100; - hsl.s = clamp01(hsl.s); - return tinycolor(hsl); - }; - tinycolor.greyscale = function(color) { - return tinycolor.desaturate(color, 100); - }; - tinycolor.lighten = function(color, amount) { - amount = (amount === 0) ? 0 : (amount || 10); - var hsl = tinycolor(color).toHsl(); - hsl.l += amount / 100; - hsl.l = clamp01(hsl.l); - return tinycolor(hsl); - }; - tinycolor.darken = function (color, amount) { - amount = (amount === 0) ? 0 : (amount || 10); - var hsl = tinycolor(color).toHsl(); - hsl.l -= amount / 100; - hsl.l = clamp01(hsl.l); - return tinycolor(hsl); - }; - tinycolor.complement = function(color) { - var hsl = tinycolor(color).toHsl(); - hsl.h = (hsl.h + 180) % 360; - return tinycolor(hsl); - }; - - - // Combination Functions - // --------------------- - // Thanks to jQuery xColor for some of the ideas behind these - // - - tinycolor.triad = function(color) { - var hsl = tinycolor(color).toHsl(); - var h = hsl.h; - return [ - tinycolor(color), - tinycolor({ h: (h + 120) % 360, s: hsl.s, l: hsl.l }), - tinycolor({ h: (h + 240) % 360, s: hsl.s, l: hsl.l }) - ]; - }; - tinycolor.tetrad = function(color) { - var hsl = tinycolor(color).toHsl(); - var h = hsl.h; - return [ - tinycolor(color), - tinycolor({ h: (h + 90) % 360, s: hsl.s, l: hsl.l }), - tinycolor({ h: (h + 180) % 360, s: hsl.s, l: hsl.l }), - tinycolor({ h: (h + 270) % 360, s: hsl.s, l: hsl.l }) - ]; - }; - tinycolor.splitcomplement = function(color) { - var hsl = tinycolor(color).toHsl(); - var h = hsl.h; - return [ - tinycolor(color), - tinycolor({ h: (h + 72) % 360, s: hsl.s, l: hsl.l}), - tinycolor({ h: (h + 216) % 360, s: hsl.s, l: hsl.l}) - ]; - }; - tinycolor.analogous = function(color, results, slices) { - results = results || 6; - slices = slices || 30; - - var hsl = tinycolor(color).toHsl(); - var part = 360 / slices; - var ret = [tinycolor(color)]; - - for (hsl.h = ((hsl.h - (part * results >> 1)) + 720) % 360; --results; ) { - hsl.h = (hsl.h + part) % 360; - ret.push(tinycolor(hsl)); - } - return ret; - }; - tinycolor.monochromatic = function(color, results) { - results = results || 6; - var hsv = tinycolor(color).toHsv(); - var h = hsv.h, s = hsv.s, v = hsv.v; - var ret = []; - var modification = 1 / results; - - while (results--) { - ret.push(tinycolor({ h: h, s: s, v: v})); - v = (v + modification) % 1; - } - - return ret; - }; - - - // Readability Functions - // --------------------- - // - - // `readability` - // Analyze the 2 colors and returns an object with the following properties: - // `brightness`: difference in brightness between the two colors - // `color`: difference in color/hue between the two colors - tinycolor.readability = function(color1, color2) { - var a = tinycolor(color1).toRgb(); - var b = tinycolor(color2).toRgb(); - var brightnessA = (a.r * 299 + a.g * 587 + a.b * 114) / 1000; - var brightnessB = (b.r * 299 + b.g * 587 + b.b * 114) / 1000; - var colorDiff = ( - Math.max(a.r, b.r) - Math.min(a.r, b.r) + - Math.max(a.g, b.g) - Math.min(a.g, b.g) + - Math.max(a.b, b.b) - Math.min(a.b, b.b) - ); - - return { - brightness: Math.abs(brightnessA - brightnessB), - color: colorDiff - }; - }; - - // `readable` - // http://www.w3.org/TR/AERT#color-contrast - // Ensure that foreground and background color combinations provide sufficient contrast. - // *Example* - // tinycolor.readable("#000", "#111") => false - tinycolor.readable = function(color1, color2) { - var readability = tinycolor.readability(color1, color2); - return readability.brightness > 125 && readability.color > 500; - }; - - // `mostReadable` - // Given a base color and a list of possible foreground or background - // colors for that base, returns the most readable color. - // *Example* - // tinycolor.mostReadable("#123", ["#fff", "#000"]) => "#000" - tinycolor.mostReadable = function(baseColor, colorList) { - var bestColor = null; - var bestScore = 0; - var bestIsReadable = false; - for (var i=0; i < colorList.length; i++) { - - // We normalize both around the "acceptable" breaking point, - // but rank brightness constrast higher than hue. - - var readability = tinycolor.readability(baseColor, colorList[i]); - var readable = readability.brightness > 125 && readability.color > 500; - var score = 3 * (readability.brightness / 125) + (readability.color / 500); - - if ((readable && ! bestIsReadable) || - (readable && bestIsReadable && score > bestScore) || - ((! readable) && (! bestIsReadable) && score > bestScore)) { - bestIsReadable = readable; - bestScore = score; - bestColor = tinycolor(colorList[i]); - } - } - return bestColor; - }; - - - // Big List of Colors - // ------------------ - // - var names = tinycolor.names = { - aliceblue: "f0f8ff", - antiquewhite: "faebd7", - aqua: "0ff", - aquamarine: "7fffd4", - azure: "f0ffff", - beige: "f5f5dc", - bisque: "ffe4c4", - black: "000", - blanchedalmond: "ffebcd", - blue: "00f", - blueviolet: "8a2be2", - brown: "a52a2a", - burlywood: "deb887", - burntsienna: "ea7e5d", - cadetblue: "5f9ea0", - chartreuse: "7fff00", - chocolate: "d2691e", - coral: "ff7f50", - cornflowerblue: "6495ed", - cornsilk: "fff8dc", - crimson: "dc143c", - cyan: "0ff", - darkblue: "00008b", - darkcyan: "008b8b", - darkgoldenrod: "b8860b", - darkgray: "a9a9a9", - darkgreen: "006400", - darkgrey: "a9a9a9", - darkkhaki: "bdb76b", - darkmagenta: "8b008b", - darkolivegreen: "556b2f", - darkorange: "ff8c00", - darkorchid: "9932cc", - darkred: "8b0000", - darksalmon: "e9967a", - darkseagreen: "8fbc8f", - darkslateblue: "483d8b", - darkslategray: "2f4f4f", - darkslategrey: "2f4f4f", - darkturquoise: "00ced1", - darkviolet: "9400d3", - deeppink: "ff1493", - deepskyblue: "00bfff", - dimgray: "696969", - dimgrey: "696969", - dodgerblue: "1e90ff", - firebrick: "b22222", - floralwhite: "fffaf0", - forestgreen: "228b22", - fuchsia: "f0f", - gainsboro: "dcdcdc", - ghostwhite: "f8f8ff", - gold: "ffd700", - goldenrod: "daa520", - gray: "808080", - green: "008000", - greenyellow: "adff2f", - grey: "808080", - honeydew: "f0fff0", - hotpink: "ff69b4", - indianred: "cd5c5c", - indigo: "4b0082", - ivory: "fffff0", - khaki: "f0e68c", - lavender: "e6e6fa", - lavenderblush: "fff0f5", - lawngreen: "7cfc00", - lemonchiffon: "fffacd", - lightblue: "add8e6", - lightcoral: "f08080", - lightcyan: "e0ffff", - lightgoldenrodyellow: "fafad2", - lightgray: "d3d3d3", - lightgreen: "90ee90", - lightgrey: "d3d3d3", - lightpink: "ffb6c1", - lightsalmon: "ffa07a", - lightseagreen: "20b2aa", - lightskyblue: "87cefa", - lightslategray: "789", - lightslategrey: "789", - lightsteelblue: "b0c4de", - lightyellow: "ffffe0", - lime: "0f0", - limegreen: "32cd32", - linen: "faf0e6", - magenta: "f0f", - maroon: "800000", - mediumaquamarine: "66cdaa", - mediumblue: "0000cd", - mediumorchid: "ba55d3", - mediumpurple: "9370db", - mediumseagreen: "3cb371", - mediumslateblue: "7b68ee", - mediumspringgreen: "00fa9a", - mediumturquoise: "48d1cc", - mediumvioletred: "c71585", - midnightblue: "191970", - mintcream: "f5fffa", - mistyrose: "ffe4e1", - moccasin: "ffe4b5", - navajowhite: "ffdead", - navy: "000080", - oldlace: "fdf5e6", - olive: "808000", - olivedrab: "6b8e23", - orange: "ffa500", - orangered: "ff4500", - orchid: "da70d6", - palegoldenrod: "eee8aa", - palegreen: "98fb98", - paleturquoise: "afeeee", - palevioletred: "db7093", - papayawhip: "ffefd5", - peachpuff: "ffdab9", - peru: "cd853f", - pink: "ffc0cb", - plum: "dda0dd", - powderblue: "b0e0e6", - purple: "800080", - red: "f00", - rosybrown: "bc8f8f", - royalblue: "4169e1", - saddlebrown: "8b4513", - salmon: "fa8072", - sandybrown: "f4a460", - seagreen: "2e8b57", - seashell: "fff5ee", - sienna: "a0522d", - silver: "c0c0c0", - skyblue: "87ceeb", - slateblue: "6a5acd", - slategray: "708090", - slategrey: "708090", - snow: "fffafa", - springgreen: "00ff7f", - steelblue: "4682b4", - tan: "d2b48c", - teal: "008080", - thistle: "d8bfd8", - tomato: "ff6347", - turquoise: "40e0d0", - violet: "ee82ee", - wheat: "f5deb3", - white: "fff", - whitesmoke: "f5f5f5", - yellow: "ff0", - yellowgreen: "9acd32" - }; - - // Make it easy to access colors via `hexNames[hex]` - var hexNames = tinycolor.hexNames = flip(names); - - - // Utilities - // --------- - - // `{ 'name1': 'val1' }` becomes `{ 'val1': 'name1' }` - function flip(o) { - var flipped = { }; - for (var i in o) { - if (o.hasOwnProperty(i)) { - flipped[o[i]] = i; - } - } - return flipped; - } - - // Return a valid alpha value [0,1] with all invalid values being set to 1 - function boundAlpha(a) { - a = parseFloat(a); - - if (isNaN(a) || a < 0 || a > 1) { - a = 1; - } - - return a; - } - - // Take input from [0, n] and return it as [0, 1] - function bound01(n, max) { - if (isOnePointZero(n)) { n = "100%"; } - - var processPercent = isPercentage(n); - n = mathMin(max, mathMax(0, parseFloat(n))); - - // Automatically convert percentage into number - if (processPercent) { - n = parseInt(n * max, 10) / 100; - } - - // Handle floating point rounding errors - if ((math.abs(n - max) < 0.000001)) { - return 1; - } - - // Convert into [0, 1] range if it isn't already - return (n % max) / parseFloat(max); - } - - // Force a number between 0 and 1 - function clamp01(val) { - return mathMin(1, mathMax(0, val)); - } - - // Parse a base-16 hex value into a base-10 integer - function parseIntFromHex(val) { - return parseInt(val, 16); - } - - // Need to handle 1.0 as 100%, since once it is a number, there is no difference between it and 1 - // - function isOnePointZero(n) { - return typeof n == "string" && n.indexOf('.') != -1 && parseFloat(n) === 1; - } - - // Check to see if string passed in is a percentage - function isPercentage(n) { - return typeof n === "string" && n.indexOf('%') != -1; - } - - // Force a hex value to have 2 characters - function pad2(c) { - return c.length == 1 ? '0' + c : '' + c; - } - - // Replace a decimal with it's percentage value - function convertToPercentage(n) { - if (n <= 1) { - n = (n * 100) + "%"; - } - - return n; - } - - // Converts a decimal to a hex value - function convertDecimalToHex(d) { - return Math.round(parseFloat(d) * 255).toString(16); - } - // Converts a hex value to a decimal - function convertHexToDecimal(h) { - return (parseIntFromHex(h) / 255); - } - - var matchers = (function() { - - // - var CSS_INTEGER = "[-\\+]?\\d+%?"; - - // - var CSS_NUMBER = "[-\\+]?\\d*\\.\\d+%?"; - - // Allow positive/negative integer/number. Don't capture the either/or, just the entire outcome. - var CSS_UNIT = "(?:" + CSS_NUMBER + ")|(?:" + CSS_INTEGER + ")"; - - // Actual matching. - // Parentheses and commas are optional, but not required. - // Whitespace can take the place of commas or opening paren - var PERMISSIVE_MATCH3 = "[\\s|\\(]+(" + CSS_UNIT + ")[,|\\s]+(" + CSS_UNIT + ")[,|\\s]+(" + CSS_UNIT + ")\\s*\\)?"; - var PERMISSIVE_MATCH4 = "[\\s|\\(]+(" + CSS_UNIT + ")[,|\\s]+(" + CSS_UNIT + ")[,|\\s]+(" + CSS_UNIT + ")[,|\\s]+(" + CSS_UNIT + ")\\s*\\)?"; - - return { - rgb: new RegExp("rgb" + PERMISSIVE_MATCH3), - rgba: new RegExp("rgba" + PERMISSIVE_MATCH4), - hsl: new RegExp("hsl" + PERMISSIVE_MATCH3), - hsla: new RegExp("hsla" + PERMISSIVE_MATCH4), - hsv: new RegExp("hsv" + PERMISSIVE_MATCH3), - hex3: /^([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})$/, - hex6: /^([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})$/, - hex8: /^([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})$/ - }; - })(); - - // `stringInputToObject` - // Permissive string parsing. Take in a number of formats, and output an object - // based on detected format. Returns `{ r, g, b }` or `{ h, s, l }` or `{ h, s, v}` - function stringInputToObject(color) { - - color = color.replace(trimLeft,'').replace(trimRight, '').toLowerCase(); - var named = false; - if (names[color]) { - color = names[color]; - named = true; - } - else if (color == 'transparent') { - return { r: 0, g: 0, b: 0, a: 0, format: "name" }; - } - - // Try to match string input using regular expressions. - // Keep most of the number bounding out of this function - don't worry about [0,1] or [0,100] or [0,360] - // Just return an object and let the conversion functions handle that. - // This way the result will be the same whether the tinycolor is initialized with string or object. - var match; - if ((match = matchers.rgb.exec(color))) { - return { r: match[1], g: match[2], b: match[3] }; - } - if ((match = matchers.rgba.exec(color))) { - return { r: match[1], g: match[2], b: match[3], a: match[4] }; - } - if ((match = matchers.hsl.exec(color))) { - return { h: match[1], s: match[2], l: match[3] }; - } - if ((match = matchers.hsla.exec(color))) { - return { h: match[1], s: match[2], l: match[3], a: match[4] }; - } - if ((match = matchers.hsv.exec(color))) { - return { h: match[1], s: match[2], v: match[3] }; - } - if ((match = matchers.hex8.exec(color))) { - return { - a: convertHexToDecimal(match[1]), - r: parseIntFromHex(match[2]), - g: parseIntFromHex(match[3]), - b: parseIntFromHex(match[4]), - format: named ? "name" : "hex8" - }; - } - if ((match = matchers.hex6.exec(color))) { - return { - r: parseIntFromHex(match[1]), - g: parseIntFromHex(match[2]), - b: parseIntFromHex(match[3]), - format: named ? "name" : "hex" - }; - } - if ((match = matchers.hex3.exec(color))) { - return { - r: parseIntFromHex(match[1] + '' + match[1]), - g: parseIntFromHex(match[2] + '' + match[2]), - b: parseIntFromHex(match[3] + '' + match[3]), - format: named ? "name" : "hex" - }; - } - - return false; - } - - // Expose tinycolor to window, does not need to run in non-browser context. - window.tinycolor = tinycolor; - - })(); - - - $(function () { - if ($.fn.spectrum.load) { - $.fn.spectrum.processNativeColorInputs(); - } - }); - -})(window, jQuery); diff --git a/library/admin/ReduxCore/assets/js/vendor/spectrum/redux-spectrum.min.js b/library/admin/ReduxCore/assets/js/vendor/spectrum/redux-spectrum.min.js deleted file mode 100644 index cd1a8138..00000000 --- a/library/admin/ReduxCore/assets/js/vendor/spectrum/redux-spectrum.min.js +++ /dev/null @@ -1 +0,0 @@ -!function(a,b,c){function d(a,b,c,d){for(var e=[],f=0;f')}else{var l="sp-clear-display";e.push('')}}return"
    "+e.join("")+"
    "}function e(){for(var a=0;aMath.abs(b-e);sa=f?"x":"y"}}else sa=null;var g=!sa||"x"===sa,h=!sa||"y"===sa;g&&(ia=parseFloat(a/_)),h&&(ja=parseFloat((aa-b)/aa)),Va=!1,T.showAlpha||(ka=1),K()},A,B),Qa?(H(Qa),L(),Ta=Sa||tinycolor(Qa).format,w(Qa)):L(),U&&E();var d=q?"mousedown.spectrum":"click.spectrum touchstart.spectrum";Fa.delegate(".sp-thumb-el",d,a),Ga.delegate(".sp-thumb-el:nth-child(1)",d,{ignore:!0},a)}function v(){if(W&&a.localStorage){try{var c=a.localStorage[W].split(",#");c.length>1&&(delete a.localStorage[W],b.each(c,function(a,b){w(b)}))}catch(d){}try{oa=a.localStorage[W].split(";")}catch(d){}}}function w(c){if(V){var d=tinycolor(c).toRgbString();if(!na[d]&&-1===b.inArray(d,oa))for(oa.push(d);oa.length>pa;)oa.shift();if(W&&a.localStorage)try{a.localStorage[W]=oa.join(";")}catch(e){}}}function x(){var a=[];if(T.showPalette)for(i=0;i=aa||0>=_||0>=ca)&&O(),wa.addClass(qa),sa=null,ua.trigger("dragstart.spectrum",[I()])}function B(){wa.removeClass(qa),ua.trigger("dragstop.spectrum",[I()])}function C(){var a=Ea.val();if(null!==a&&""!==a||!Wa){var b=tinycolor(a);b.ok?(H(b),N(!0)):Ea.addClass("sp-validation-error")}else H(null),N(!0)}function D(){$?F():E()}function E(){var c=b.Event("beforeShow.spectrum");return $?void O():(ua.trigger(c,[I()]),void(Y.beforeShow(I())===!1||c.isDefaultPrevented()||(e(),$=!0,b(ta).bind("click.spectrum",F),b(a).bind("resize.spectrum",Z),Na.addClass("sp-active"),wa.removeClass("sp-hidden"),O(),L(),Ra=I(),z(),Y.show(Ra),ua.trigger("show.spectrum",[Ra]))))}function F(c){if((!c||"click"!=c.type||2!=c.button)&&$&&!U){$=!1,b(ta).unbind("click.spectrum",F),b(a).unbind("resize.spectrum",Z),Na.removeClass("sp-active"),wa.addClass("sp-hidden");var d=!tinycolor.equals(I(),Ra);d&&(Ua&&"cancel"!==c?N(!0):G()),Y.hide(I()),ua.trigger("hide.spectrum",[I()])}}function G(){H(Ra,!0)}function H(a,b){if(tinycolor.equals(a,I()))return void L();var c,d;!a&&Wa?Va=!0:(Va=!1,c=tinycolor(a),d=c.toHsv(),ha=d.h%360/360,ia=d.s,ja=d.v,ka=d.a),L(),c&&c.ok&&!b&&(Ta=Sa||c.format)}function I(a){return a=a||{},Wa&&Va?null:tinycolor.fromRatio({h:ha,s:ia,v:ja,a:Math.round(100*ka)/100},{format:a.format||Ta})}function J(){return!Ea.hasClass("sp-validation-error")}function K(){L(),Y.move(I()),ua.trigger("move.spectrum",[I()])}function L(){Ea.removeClass("sp-validation-error"),M();var a=tinycolor.fromRatio({h:ha,s:1,v:1});xa.css("background-color",a.toHexString());var b=Ta;1>ka&&(0!==ka||"name"!==b)&&("hex"===b||"hex3"===b||"hex6"===b||"name"===b)&&(b="rgb");var c=I({format:b}),d="";if(Pa.removeClass("sp-clear-display"),Pa.css("background-color","transparent"),!c&&Wa)Pa.addClass("sp-clear-display");else{var e=c.toHexString(),f=c.toRgbString();if(r||1===c.alpha?Pa.css("background-color",f):(Pa.css("background-color","transparent"),Pa.css("filter",c.toFilter())),T.showAlpha){var g=c.toRgb();g.a=0;var h=tinycolor(g).toRgbString(),i="linear-gradient(left, "+h+", "+e+")";q?Ba.css("filter",tinycolor(h).toFilter({gradientType:1},e)):(Ba.css("background","-webkit-"+i),Ba.css("background","-moz-"+i),Ba.css("background","-ms-"+i),Ba.css("background","linear-gradient(to right, "+h+", "+e+")"))}d=c.toString(b)}T.showInput&&Ea.val(d),T.showPalette&&y(),z()}function M(){var a=ia,b=ja;if(Wa&&Va)Da.hide(),Aa.hide(),ya.hide();else{Da.show(),Aa.show(),ya.show();var c=a*_,d=aa-b*aa;c=Math.max(-ba,Math.min(_-ba,c-ba)),d=Math.max(-ba,Math.min(aa-ba,d-ba)),ya.css({top:d+"px",left:c+"px"});var e=ka*ea;Da.css({left:e-fa/2+"px"});var f=ha*ca;Aa.css({top:f-ga+"px"})}}function N(a){var b=I(),c="",d=!tinycolor.equals(b,Ra);b&&(c=b.toString(Ta),w(b)),Ka&&ua.val(c),Ra=b,a&&d&&(Y.change(b),ua.trigger("change",[b]))}function O(){_=xa.width(),aa=xa.height(),ba=ya.height(),da=za.width(),ca=za.height(),ga=Aa.height(),ea=Ca.width(),fa=Da.width(),U||(wa.css("position","absolute"),wa.offset(h(wa,Oa))),M(),T.showPalette&&y(),ua.trigger("reflow.spectrum")}function P(){ua.show(),Oa.unbind("click.spectrum touchstart.spectrum"),wa.remove(),Na.remove(),p[Ya.id]=null}function Q(a,d){return a===c?b.extend({},T):d===c?T[a]:(T[a]=d,void l())}function R(){va=!1,ua.attr("disabled",!1),Oa.removeClass("sp-disabled")}function S(){F(),va=!0,ua.attr("disabled",!0),Oa.addClass("sp-disabled")}var T=f(j,g),U=T.flat,V=T.showSelectionPalette,W=T.localStorageKey,X=T.theme,Y=T.callbacks,Z=n(O,10),$=!1,_=0,aa=0,ba=0,ca=0,da=0,ea=0,fa=0,ga=0,ha=0,ia=0,ja=0,ka=1,la=[],ma=[],na={},oa=T.selectionPalette.slice(0),pa=T.maxSelectionSize,qa="sp-dragging",ra=T.inputText,sa=null,ta=g.ownerDocument,ua=(ta.body,b(g)),va=!1,wa=b(u,ta).addClass(X),xa=wa.find(".sp-color"),ya=wa.find(".sp-dragger"),za=wa.find(".sp-hue"),Aa=wa.find(".sp-slider"),Ba=wa.find(".sp-alpha-inner"),Ca=wa.find(".sp-alpha"),Da=wa.find(".sp-alpha-handle"),Ea=wa.find(".sp-input"),Fa=wa.find(".sp-palette"),Ga=wa.find(".sp-initial"),Ha=wa.find(".sp-cancel"),Ia=wa.find(".sp-clear"),Ja=wa.find(".sp-choose"),Ka=ua.is("input"),La=Ka&&s&&"color"===ua.attr("type"),Ma=Ka&&!U,Na=Ma?b(t).addClass(X).addClass(T.className).addClass(T.replacerClassName):b([]),Oa=Ma?Na:ua,Pa=Na.find(".sp-preview-inner"),Qa=T.color||Ka&&ua.val(),Ra=!1,Sa=T.preferredFormat,Ta=Sa,Ua=!T.showButtons||T.clickoutFiresChange,Va=!Qa,Wa=T.allowEmpty&&!La;if(""!==ra){var Xa=b(Oa).find("div.sp-dd");Xa.text(ra)}o();var Ya={show:E,hide:F,toggle:D,reflow:O,option:Q,enable:R,disable:S,set:function(a){H(a),N()},get:I,destroy:P,container:wa};return Ya.id=p.push(Ya)-1,Ya}function h(a,c){var d=0,e=a.outerWidth(),f=a.outerHeight(),g=c.outerHeight(),h=a[0].ownerDocument,i=h.documentElement,j=i.clientWidth+b(h).scrollLeft(),k=i.clientHeight+b(h).scrollTop(),l=c.offset();return l.top+=g,l.left-=Math.min(l.left,l.left+e>j&&j>e?Math.abs(l.left+e-j):0),l.top-=Math.min(l.top,l.top+f>k&&k>f?Math.abs(f+g-d):d),l}function j(){}function k(a){a.stopPropagation()}function l(a,b){var c=Array.prototype.slice,d=c.call(arguments,2);return function(){return a.apply(b,d.concat(c.call(arguments)))}}function m(c,d,e,f){function g(a){a.stopPropagation&&a.stopPropagation(),a.preventDefault&&a.preventDefault(),a.returnValue=!1}function h(a){if(l){if(q&&document.documentMode<9&&!a.button)return j();var b=a.originalEvent.touches,e=b?b[0].pageX:a.pageX,f=b?b[0].pageY:a.pageY,h=Math.max(0,Math.min(e-m.left,o)),i=Math.max(0,Math.min(f-m.top,n));p&&g(a),d.apply(c,[h,i,a])}}function i(a){var d=a.which?3==a.which:2==a.button;a.originalEvent.touches;d||l||e.apply(c,arguments)!==!1&&(l=!0,n=b(c).height(),o=b(c).width(),m=b(c).offset(),b(k).bind(r),b(k.body).addClass("sp-dragging"),p||h(a),g(a))}function j(){l&&(b(k).unbind(r),b(k.body).removeClass("sp-dragging"),f.apply(c,arguments)),l=!1}d=d||function(){},e=e||function(){},f=f||function(){};var k=c.ownerDocument||document,l=!1,m={},n=0,o=0,p="ontouchstart"in a,r={};r.selectstart=g,r.dragstart=g,r["touchmove mousemove"]=h,r["touchend mouseup"]=j,b(c).bind("touchstart mousedown",i)}function n(a,b,c){var d;return function(){var e=this,f=arguments,g=function(){d=null,a.apply(e,f)};c&&clearTimeout(d),(c||!d)&&(d=setTimeout(g,b))}}var o={beforeShow:j,move:j,change:j,show:j,hide:j,color:!1,flat:!1,showInput:!1,allowEmpty:!1,showButtons:!0,clickoutFiresChange:!1,showInitial:!1,showPalette:!1,showPaletteOnly:!1,showSelectionPalette:!0,localStorageKey:!1,appendTo:"body",maxSelectionSize:7,cancelText:"cancel",chooseText:"choose",clearText:"Clear Color Selection",preferredFormat:!1,className:"",containerClassName:"",replacerClassName:"",showAlpha:!1,theme:"sp-light",palette:[["#ffffff","#000000","#ff0000","#ff8000","#ffff00","#008000","#0000ff","#4b0082","#9400d3"]],selectionPalette:[],disabled:!1,inputText:""},p=[],q=!!/msie/i.exec(a.navigator.userAgent),r=function(){function a(a,b){return!!~(""+a).indexOf(b)}var b=document.createElement("div"),c=b.style;return c.cssText="background-color:rgba(0,0,0,.5)",a(c.backgroundColor,"rgba")||a(c.backgroundColor,"hsla")}(),s=function(){var a=b("")[0];return"color"===a.type&&"#ffffff"!==a.value}(),t=["
    ","
    ","
    ","
    "].join(""),u=function(){var a="";if(q)for(var b=1;6>=b;b++)a+="
    ";return["
    ","
    ","
    ","
    ","
    ","
    ","
    ","
    ","
    ","
    ","
    ","
    ","
    ","
    ","
    ","
    ","
    ","
    ","
    ",a,"
    ","
    ","
    ","
    ","
    ","","
    ","
    ","
    ","","","
    ","
    ","
    "].join("")}(),v="spectrum.id";b.fn.spectrum=function(a,c){if("string"==typeof a){var d=this,e=Array.prototype.slice.call(arguments,1);return this.each(function(){var c=p[b(this).data(v)];if(c){var f=c[a];if(!f)throw new Error("Spectrum: no such method: '"+a+"'");"get"==a?d=c.get():"container"==a?d=c.container:"option"==a?d=c.option.apply(c,e):"destroy"==a?(c.destroy(),b(this).removeData(v)):f.apply(c,e)}}),d}return this.spectrum("destroy").each(function(){var c=b.extend({},a,b(this).data()),d=g(this,c);b(this).data(v,d.id)})},b.fn.spectrum.load=!0,b.fn.spectrum.loadOpts={},b.fn.spectrum.draggable=m,b.fn.spectrum.defaults=o,b.spectrum={},b.spectrum.localization={},b.spectrum.palettes={},b.fn.spectrum.processNativeColorInputs=function(){s||b("input[type=color]").spectrum({preferredFormat:"hex6"})},function(){function b(a,d){if(a=a?a:"",d=d||{},"object"==typeof a&&a.hasOwnProperty("_tc_id"))return a;var f=c(a),h=f.r,k=f.g,n=f.b,o=f.a,p=A(100*o)/100,q=d.format||f.format;return 1>h&&(h=A(h)),1>k&&(k=A(k)),1>n&&(n=A(n)),{ok:f.ok,format:q,_tc_id:y++,alpha:o,getAlpha:function(){return o},setAlpha:function(a){o=l(a),p=A(100*o)/100},toHsv:function(){var a=g(h,k,n);return{h:360*a.h,s:a.s,v:a.v,a:o}},toHsvString:function(){var a=g(h,k,n),b=A(360*a.h),c=A(100*a.s),d=A(100*a.v);return 1==o?"hsv("+b+", "+c+"%, "+d+"%)":"hsva("+b+", "+c+"%, "+d+"%, "+p+")"},toHsl:function(){var a=e(h,k,n);return{h:360*a.h,s:a.s,l:a.l,a:o}},toHslString:function(){var a=e(h,k,n),b=A(360*a.h),c=A(100*a.s),d=A(100*a.l);return 1==o?"hsl("+b+", "+c+"%, "+d+"%)":"hsla("+b+", "+c+"%, "+d+"%, "+p+")"},toHex:function(a){return i(h,k,n,a)},toHexString:function(a){return"#"+this.toHex(a)},toHex8:function(){return j(h,k,n,o)},toHex8String:function(){return"#"+this.toHex8()},toRgb:function(){return{r:A(h),g:A(k),b:A(n),a:o}},toRgbString:function(){return 1==o?"rgb("+A(h)+", "+A(k)+", "+A(n)+")":"rgba("+A(h)+", "+A(k)+", "+A(n)+", "+p+")"},toPercentageRgb:function(){return{r:A(100*m(h,255))+"%",g:A(100*m(k,255))+"%",b:A(100*m(n,255))+"%",a:o}},toPercentageRgbString:function(){return 1==o?"rgb("+A(100*m(h,255))+"%, "+A(100*m(k,255))+"%, "+A(100*m(n,255))+"%)":"rgba("+A(100*m(h,255))+"%, "+A(100*m(k,255))+"%, "+A(100*m(n,255))+"%, "+p+")"},toName:function(){return 0===o?"transparent":F[i(h,k,n,!0)]||!1},toFilter:function(a){var c="#"+j(h,k,n,o),e=c,f=d&&d.gradientType?"GradientType = 1, ":"";if(a){var g=b(a);e=g.toHex8String()}return"progid:DXImageTransform.Microsoft.gradient("+f+"startColorstr="+c+",endColorstr="+e+")"},toString:function(a){var b=!!a;a=a||this.format;var c=!1,d=!b&&1>o&&o>0,e=d&&("hex"===a||"hex6"===a||"hex3"===a||"name"===a);return"rgb"===a&&(c=this.toRgbString()),"prgb"===a&&(c=this.toPercentageRgbString()),("hex"===a||"hex6"===a)&&(c=this.toHexString()),"hex3"===a&&(c=this.toHexString(!0)),"hex8"===a&&(c=this.toHex8String()),"name"===a&&(c=this.toName()),"hsl"===a&&(c=this.toHslString()),"hsv"===a&&(c=this.toHsvString()),e?this.toRgbString():c||this.toHexString()}}}function c(a){var b={r:0,g:0,b:0},c=1,e=!1,g=!1;return"string"==typeof a&&(a=v(a)),"object"==typeof a&&(a.hasOwnProperty("r")&&a.hasOwnProperty("g")&&a.hasOwnProperty("b")?(b=d(a.r,a.g,a.b),e=!0,g="%"===String(a.r).substr(-1)?"prgb":"rgb"):a.hasOwnProperty("h")&&a.hasOwnProperty("s")&&a.hasOwnProperty("v")?(a.s=s(a.s),a.v=s(a.v),b=h(a.h,a.s,a.v),e=!0,g="hsv"):a.hasOwnProperty("h")&&a.hasOwnProperty("s")&&a.hasOwnProperty("l")&&(a.s=s(a.s),a.l=s(a.l),b=f(a.h,a.s,a.l),e=!0,g="hsl"),a.hasOwnProperty("a")&&(c=a.a)),c=l(c),{ok:e,format:a.format||g,r:B(255,C(b.r,0)),g:B(255,C(b.g,0)),b:B(255,C(b.b,0)),a:c}}function d(a,b,c){return{r:255*m(a,255),g:255*m(b,255),b:255*m(c,255)}}function e(a,b,c){a=m(a,255),b=m(b,255),c=m(c,255);var d,e,f=C(a,b,c),g=B(a,b,c),h=(f+g)/2;if(f==g)d=e=0;else{var i=f-g;switch(e=h>.5?i/(2-f-g):i/(f+g),f){case a:d=(b-c)/i+(c>b?6:0);break;case b:d=(c-a)/i+2;break;case c:d=(a-b)/i+4}d/=6}return{h:d,s:e,l:h}}function f(a,b,c){function d(a,b,c){return 0>c&&(c+=1),c>1&&(c-=1),1/6>c?a+6*(b-a)*c:.5>c?b:2/3>c?a+(b-a)*(2/3-c)*6:a}var e,f,g;if(a=m(a,360),b=m(b,100),c=m(c,100),0===b)e=f=g=c;else{var h=.5>c?c*(1+b):c+b-c*b,i=2*c-h;e=d(i,h,a+1/3),f=d(i,h,a),g=d(i,h,a-1/3)}return{r:255*e,g:255*f,b:255*g}}function g(a,b,c){a=m(a,255),b=m(b,255),c=m(c,255);var d,e,f=C(a,b,c),g=B(a,b,c),h=f,i=f-g;if(e=0===f?0:i/f,f==g)d=0;else{switch(f){case a:d=(b-c)/i+(c>b?6:0);break;case b:d=(c-a)/i+2;break;case c:d=(a-b)/i+4}d/=6}return{h:d,s:e,v:h}}function h(a,b,c){a=6*m(a,360),b=m(b,100),c=m(c,100);var d=z.floor(a),e=a-d,f=c*(1-b),g=c*(1-e*b),h=c*(1-(1-e)*b),i=d%6,j=[c,g,f,f,h,c][i],k=[h,c,c,g,f,f][i],l=[f,f,h,c,c,g][i];return{r:255*j,g:255*k,b:255*l}}function i(a,b,c,d){var e=[r(A(a).toString(16)),r(A(b).toString(16)),r(A(c).toString(16))];return d&&e[0].charAt(0)==e[0].charAt(1)&&e[1].charAt(0)==e[1].charAt(1)&&e[2].charAt(0)==e[2].charAt(1)?e[0].charAt(0)+e[1].charAt(0)+e[2].charAt(0):e.join("")}function j(a,b,c,d){var e=[r(t(d)),r(A(a).toString(16)),r(A(b).toString(16)),r(A(c).toString(16))];return e.join("")}function k(a){var b={};for(var c in a)a.hasOwnProperty(c)&&(b[a[c]]=c);return b}function l(a){return a=parseFloat(a),(isNaN(a)||0>a||a>1)&&(a=1),a}function m(a,b){p(a)&&(a="100%");var c=q(a);return a=B(b,C(0,parseFloat(a))),c&&(a=parseInt(a*b,10)/100),z.abs(a-b)<1e-6?1:a%b/parseFloat(b)}function n(a){return B(1,C(0,a))}function o(a){return parseInt(a,16)}function p(a){return"string"==typeof a&&-1!=a.indexOf(".")&&1===parseFloat(a)}function q(a){return"string"==typeof a&&-1!=a.indexOf("%")}function r(a){return 1==a.length?"0"+a:""+a}function s(a){return 1>=a&&(a=100*a+"%"),a}function t(a){return Math.round(255*parseFloat(a)).toString(16)}function u(a){return o(a)/255}function v(a){a=a.replace(w,"").replace(x,"").toLowerCase();var b=!1;if(E[a])a=E[a],b=!0;else if("transparent"==a)return{r:0,g:0,b:0,a:0,format:"name"};var c;return(c=G.rgb.exec(a))?{r:c[1],g:c[2],b:c[3]}:(c=G.rgba.exec(a))?{r:c[1],g:c[2],b:c[3],a:c[4]}:(c=G.hsl.exec(a))?{h:c[1],s:c[2],l:c[3]}:(c=G.hsla.exec(a))?{h:c[1],s:c[2],l:c[3],a:c[4]}:(c=G.hsv.exec(a))?{h:c[1],s:c[2],v:c[3]}:(c=G.hex8.exec(a))?{a:u(c[1]),r:o(c[2]),g:o(c[3]),b:o(c[4]),format:b?"name":"hex8"}:(c=G.hex6.exec(a))?{r:o(c[1]),g:o(c[2]),b:o(c[3]),format:b?"name":"hex"}:(c=G.hex3.exec(a))?{r:o(c[1]+""+c[1]),g:o(c[2]+""+c[2]),b:o(c[3]+""+c[3]),format:b?"name":"hex"}:!1}var w=/^[\s,#]+/,x=/\s+$/,y=0,z=Math,A=z.round,B=z.min,C=z.max,D=z.random;b.fromRatio=function(a,c){if("object"==typeof a){var d={};for(var e in a)a.hasOwnProperty(e)&&("a"===e?d[e]=a[e]:d[e]=s(a[e]));a=d}return b(a,c)},b.equals=function(a,c){return a&&c?b(a).toRgbString()==b(c).toRgbString():!1},b.random=function(){return b.fromRatio({r:D(),g:D(),b:D()})},b.desaturate=function(a,c){c=0===c?0:c||10;var d=b(a).toHsl();return d.s-=c/100,d.s=n(d.s),b(d)},b.saturate=function(a,c){c=0===c?0:c||10;var d=b(a).toHsl();return d.s+=c/100,d.s=n(d.s),b(d)},b.greyscale=function(a){return b.desaturate(a,100)},b.lighten=function(a,c){c=0===c?0:c||10;var d=b(a).toHsl();return d.l+=c/100,d.l=n(d.l),b(d)},b.darken=function(a,c){c=0===c?0:c||10;var d=b(a).toHsl();return d.l-=c/100,d.l=n(d.l),b(d)},b.complement=function(a){var c=b(a).toHsl();return c.h=(c.h+180)%360,b(c)},b.triad=function(a){var c=b(a).toHsl(),d=c.h;return[b(a),b({h:(d+120)%360,s:c.s,l:c.l}),b({h:(d+240)%360,s:c.s,l:c.l})]},b.tetrad=function(a){var c=b(a).toHsl(),d=c.h;return[b(a),b({h:(d+90)%360,s:c.s,l:c.l}),b({h:(d+180)%360,s:c.s,l:c.l}),b({h:(d+270)%360,s:c.s,l:c.l})]},b.splitcomplement=function(a){var c=b(a).toHsl(),d=c.h;return[b(a),b({h:(d+72)%360,s:c.s,l:c.l}),b({h:(d+216)%360,s:c.s,l:c.l})]},b.analogous=function(a,c,d){c=c||6,d=d||30;var e=b(a).toHsl(),f=360/d,g=[b(a)];for(e.h=(e.h-(f*c>>1)+720)%360;--c;)e.h=(e.h+f)%360,g.push(b(e));return g},b.monochromatic=function(a,c){c=c||6;for(var d=b(a).toHsv(),e=d.h,f=d.s,g=d.v,h=[],i=1/c;c--;)h.push(b({h:e,s:f,v:g})),g=(g+i)%1;return h},b.readability=function(a,c){var d=b(a).toRgb(),e=b(c).toRgb(),f=(299*d.r+587*d.g+114*d.b)/1e3,g=(299*e.r+587*e.g+114*e.b)/1e3,h=Math.max(d.r,e.r)-Math.min(d.r,e.r)+Math.max(d.g,e.g)-Math.min(d.g,e.g)+Math.max(d.b,e.b)-Math.min(d.b,e.b);return{brightness:Math.abs(f-g),color:h}},b.readable=function(a,c){var d=b.readability(a,c);return d.brightness>125&&d.color>500},b.mostReadable=function(a,c){for(var d=null,e=0,f=!1,g=0;g125&&h.color>500,j=3*(h.brightness/125)+h.color/500;(i&&!f||i&&f&&j>e||!i&&!f&&j>e)&&(f=i,e=j,d=b(c[g]))}return d};var E=b.names={aliceblue:"f0f8ff",antiquewhite:"faebd7",aqua:"0ff",aquamarine:"7fffd4",azure:"f0ffff",beige:"f5f5dc",bisque:"ffe4c4",black:"000",blanchedalmond:"ffebcd",blue:"00f",blueviolet:"8a2be2",brown:"a52a2a",burlywood:"deb887",burntsienna:"ea7e5d",cadetblue:"5f9ea0",chartreuse:"7fff00",chocolate:"d2691e",coral:"ff7f50",cornflowerblue:"6495ed",cornsilk:"fff8dc",crimson:"dc143c",cyan:"0ff",darkblue:"00008b",darkcyan:"008b8b",darkgoldenrod:"b8860b",darkgray:"a9a9a9",darkgreen:"006400",darkgrey:"a9a9a9",darkkhaki:"bdb76b",darkmagenta:"8b008b",darkolivegreen:"556b2f",darkorange:"ff8c00",darkorchid:"9932cc",darkred:"8b0000",darksalmon:"e9967a",darkseagreen:"8fbc8f",darkslateblue:"483d8b",darkslategray:"2f4f4f",darkslategrey:"2f4f4f",darkturquoise:"00ced1",darkviolet:"9400d3",deeppink:"ff1493",deepskyblue:"00bfff",dimgray:"696969",dimgrey:"696969",dodgerblue:"1e90ff",firebrick:"b22222",floralwhite:"fffaf0",forestgreen:"228b22",fuchsia:"f0f",gainsboro:"dcdcdc",ghostwhite:"f8f8ff",gold:"ffd700",goldenrod:"daa520",gray:"808080",green:"008000",greenyellow:"adff2f",grey:"808080",honeydew:"f0fff0",hotpink:"ff69b4",indianred:"cd5c5c",indigo:"4b0082",ivory:"fffff0",khaki:"f0e68c",lavender:"e6e6fa",lavenderblush:"fff0f5",lawngreen:"7cfc00",lemonchiffon:"fffacd",lightblue:"add8e6",lightcoral:"f08080",lightcyan:"e0ffff",lightgoldenrodyellow:"fafad2",lightgray:"d3d3d3",lightgreen:"90ee90",lightgrey:"d3d3d3",lightpink:"ffb6c1",lightsalmon:"ffa07a",lightseagreen:"20b2aa",lightskyblue:"87cefa",lightslategray:"789",lightslategrey:"789",lightsteelblue:"b0c4de",lightyellow:"ffffe0",lime:"0f0",limegreen:"32cd32",linen:"faf0e6",magenta:"f0f",maroon:"800000",mediumaquamarine:"66cdaa",mediumblue:"0000cd",mediumorchid:"ba55d3",mediumpurple:"9370db",mediumseagreen:"3cb371",mediumslateblue:"7b68ee",mediumspringgreen:"00fa9a",mediumturquoise:"48d1cc",mediumvioletred:"c71585",midnightblue:"191970",mintcream:"f5fffa",mistyrose:"ffe4e1",moccasin:"ffe4b5",navajowhite:"ffdead",navy:"000080",oldlace:"fdf5e6",olive:"808000",olivedrab:"6b8e23",orange:"ffa500",orangered:"ff4500",orchid:"da70d6",palegoldenrod:"eee8aa",palegreen:"98fb98",paleturquoise:"afeeee",palevioletred:"db7093",papayawhip:"ffefd5",peachpuff:"ffdab9",peru:"cd853f",pink:"ffc0cb",plum:"dda0dd",powderblue:"b0e0e6",purple:"800080",red:"f00",rosybrown:"bc8f8f",royalblue:"4169e1",saddlebrown:"8b4513",salmon:"fa8072",sandybrown:"f4a460",seagreen:"2e8b57",seashell:"fff5ee",sienna:"a0522d",silver:"c0c0c0",skyblue:"87ceeb",slateblue:"6a5acd",slategray:"708090",slategrey:"708090",snow:"fffafa",springgreen:"00ff7f",steelblue:"4682b4",tan:"d2b48c",teal:"008080",thistle:"d8bfd8",tomato:"ff6347",turquoise:"40e0d0",violet:"ee82ee",wheat:"f5deb3",white:"fff",whitesmoke:"f5f5f5",yellow:"ff0",yellowgreen:"9acd32"},F=b.hexNames=k(E),G=function(){var a="[-\\+]?\\d+%?",b="[-\\+]?\\d*\\.\\d+%?",c="(?:"+b+")|(?:"+a+")",d="[\\s|\\(]+("+c+")[,|\\s]+("+c+")[,|\\s]+("+c+")\\s*\\)?",e="[\\s|\\(]+("+c+")[,|\\s]+("+c+")[,|\\s]+("+c+")[,|\\s]+("+c+")\\s*\\)?";return{rgb:new RegExp("rgb"+d),rgba:new RegExp("rgba"+e),hsl:new RegExp("hsl"+d),hsla:new RegExp("hsla"+e),hsv:new RegExp("hsv"+d),hex3:/^([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})$/,hex6:/^([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})$/,hex8:/^([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})$/}}();a.tinycolor=b}(),b(function(){b.fn.spectrum.load&&b.fn.spectrum.processNativeColorInputs()})}(window,jQuery); \ No newline at end of file diff --git a/library/admin/ReduxCore/core/dashboard.php b/library/admin/ReduxCore/core/dashboard.php deleted file mode 100644 index b45a9d0e..00000000 --- a/library/admin/ReduxCore/core/dashboard.php +++ /dev/null @@ -1,32 +0,0 @@ -'; - wp_widget_rss_output(array( - 'url' => 'http://reduxframework.com/feed/', - 'title' => 'REDUX_NEWS', - 'items' => 3, - 'show_summary' => 1, - 'show_author' => 0, - 'show_date' => 1 - )); - echo '
    '; - } - } - - new reduxDashboardWidget(); - } diff --git a/library/admin/ReduxCore/core/enqueue.php b/library/admin/ReduxCore/core/enqueue.php deleted file mode 100644 index 7c5ad3bb..00000000 --- a/library/admin/ReduxCore/core/enqueue.php +++ /dev/null @@ -1,510 +0,0 @@ -parent = $parent; - - Redux_Functions::$_parent = $parent; - } - - public function init() { - $this->min = Redux_Functions::isMin(); - - $this->timestamp = ReduxFramework::$_version; - if ( $this->parent->args['dev_mode'] ) { - $this->timestamp .= '.' . time(); - } - - $this->register_styles(); - $this->register_scripts(); - - add_thickbox(); - - $this->enqueue_fields(); - - $this->set_localized_data(); - - /** - * action 'redux-enqueue-{opt_name}' - * - * @deprecated - * - * @param object $this ReduxFramework - */ - do_action( "redux-enqueue-{$this->parent->args['opt_name']}", $this->parent ); // REMOVE - - /** - * action 'redux/page/{opt_name}/enqueue' - */ - do_action( "redux/page/{$this->parent->args['opt_name']}/enqueue" ); - } - - private function register_styles() { - - //***************************************************************** - // Redux Admin CSS - //***************************************************************** - wp_enqueue_style( - 'redux-admin-css', - ReduxFramework::$_url . 'assets/css/redux-admin.css', - array(), - $this->timestamp, - 'all' - ); - - //***************************************************************** - // Redux Fields CSS - //***************************************************************** - if ( ! $this->parent->args['dev_mode'] ) { - wp_enqueue_style( - 'redux-fields-css', - ReduxFramework::$_url . 'assets/css/redux-fields.css', - array(), - $this->timestamp, - 'all' - ); - } - - //***************************************************************** - // Select2 CSS - //***************************************************************** - Redux_CDN::register_style( - 'select2-css', - '//cdn.jsdelivr.net/select2/3.5.2/select2.css', - array(), - '3.5.2',//$this->timestamp, - 'all' - ); - - //***************************************************************** - // Spectrum CSS - //***************************************************************** - $css_file = 'redux-spectrum.min.css'; - if ($this->parent->args['dev_mode']) { - $css_file = 'redux-spectrum.css'; - } - - wp_register_style( - 'redux-spectrum-css', - ReduxFramework::$_url . 'assets/css/vendor/spectrum/' . $css_file, - array(), - '1.3.3', - 'all' - ); - - //***************************************************************** - // Elusive Icon CSS - //***************************************************************** - wp_enqueue_style( - 'redux-elusive-icon', - ReduxFramework::$_url . 'assets/css/vendor/elusive-icons/elusive-icons.css', - array(), - $this->timestamp, - 'all' - ); - - //***************************************************************** - // QTip CSS - //***************************************************************** - $css_file = 'jquery.qtip.min.css'; - if ($this->parent->args['dev_mode']) { - $css_file = 'jquery.qtip.css'; - } - - wp_enqueue_style( - 'qtip-css', - ReduxFramework::$_url . 'assets/css/vendor/qtip/' . $css_file, - array(), - '2.2.0', - 'all' - ); - - //***************************************************************** - // JQuery UI CSS - //***************************************************************** - wp_enqueue_style( - 'jquery-ui-css', - apply_filters( "redux/page/{$this->parent->args['opt_name']}/enqueue/jquery-ui-css", ReduxFramework::$_url . 'assets/css/vendor/jquery-ui-bootstrap/jquery-ui-1.10.0.custom.css' ), - array(), - $this->timestamp, - 'all' - ); - - //***************************************************************** - // Iris CSS - //***************************************************************** - wp_enqueue_style( 'wp-color-picker' ); - - if ( $this->parent->args['dev_mode'] ) { - - //***************************************************************** - // Color Picker CSS - //***************************************************************** - wp_register_style( - 'redux-color-picker-css', - ReduxFramework::$_url . 'assets/css/color-picker/color-picker.css', - array( 'wp-color-picker' ), - $this->timestamp, - 'all' - ); - - //***************************************************************** - // Media CSS - //***************************************************************** - wp_enqueue_style( - 'redux-field-media-css', - ReduxFramework::$_url . 'assets/css/media/media.css', - array(), - time(), - 'all' - ); - } - - //***************************************************************** - // RTL CSS - //***************************************************************** - if ( is_rtl() ) { - wp_enqueue_style( - 'redux-rtl-css', - ReduxFramework::$_url . 'assets/css/rtl.css', - array( 'redux-admin-css' ), - $this->timestamp, - 'all' - ); - } - - } - - private function register_scripts() { - //***************************************************************** - // JQuery / JQuery UI JS - //***************************************************************** - wp_enqueue_script( 'jquery' ); - wp_enqueue_script( 'jquery-ui-core' ); - wp_enqueue_script( 'jquery-ui-dialog' ); - - //***************************************************************** - // Select2 Sortable JS - //***************************************************************** - wp_register_script( - 'redux-select2-sortable-js', - ReduxFramework::$_url . 'assets/js/vendor/redux.select2.sortable' . $this->min . '.js', - array( 'jquery' ), - $this->timestamp, - true - ); - - //***************************************************************** - // Select2 JS - //***************************************************************** - - // JWp6 plugin giving us problems. They need to update. - if ( wp_script_is ( 'jquerySelect2' )) { - wp_deregister_script( 'jquerySelect2' ); - wp_dequeue_script('jquerySelect2'); - wp_dequeue_style('jquerySelect2Style'); - } - - - Redux_CDN::register_script( - 'select2-js', - '//cdn.jsdelivr.net/select2/3.5.2/select2' . $this->min . '.js', - array( 'jquery', 'redux-select2-sortable-js' ), - '3.5.2', - true - ); - - //***************************************************************** - // QTip JS - //***************************************************************** - $js_file = 'jquery.qtip.min.js'; - if ($this->parent->args['dev_mode']) { - $js_file = 'jquery.qtip.js'; - } - - wp_enqueue_script( - 'qtip-js', - ReduxFramework::$_url . 'assets/js/vendor/qtip/' . $js_file, - array( 'jquery' ), - '2.2.0', - true - ); - - //***************************************************************** - // Spectrum JS - //***************************************************************** - $js_file = 'redux-spectrum.min.js'; - if ($this->parent->args['dev_mode']) { - $js_file = 'redux-spectrum.js'; - } - - wp_register_script( - 'redux-spectrum-js', - ReduxFramework::$_url . 'assets/js/vendor/spectrum/' . $js_file, - array( 'jquery' ), - '1.3.3', - true - ); - - $depArray = array( 'jquery' ); - - //***************************************************************** - // Vendor JS - //***************************************************************** - if ( $this->parent->args['dev_mode'] ) { - wp_register_script( - 'redux-vendor', - ReduxFramework::$_url . 'assets/js/vendor.min.js', - array( 'jquery' ), - $this->timestamp, - true - ); - - array_push( $depArray, 'redux-vendor' ); - } - - //***************************************************************** - // Redux JS - //***************************************************************** - wp_register_script( - 'redux-js', - ReduxFramework::$_url . 'assets/js/redux' . $this->min . '.js', - $depArray, - $this->timestamp, - true - ); - - wp_enqueue_script( - 'webfontloader', - 'https://ajax.googleapis.com/ajax/libs/webfont/1.5.0/webfont.js', - array( 'jquery' ), - '1.5.0', - true - ); - } - - public function _enqueue_field($field) { - // TODO AFTER GROUP WORKS - Revert IF below - // if( isset( $field['type'] ) && $field['type'] != 'callback' ) { - if ( isset( $field['type'] ) && $field['type'] != 'callback' ) { - - $field_class = 'ReduxFramework_' . $field['type']; - - /** - * Field class file - * filter 'redux/{opt_name}/field/class/{field.type} - * - * @param string field class file path - * @param array $field field config data - */ - $class_file = apply_filters( "redux/{$this->parent->args['opt_name']}/field/class/{$field['type']}", ReduxFramework::$_dir . "inc/fields/{$field['type']}/field_{$field['type']}.php", $field ); - if ( $class_file ) { - if ( ! class_exists( $field_class ) ) { - if ( file_exists( $class_file ) ) { - require_once $class_file; - } - } - - if ( ( method_exists( $field_class, 'enqueue' ) ) || method_exists( $field_class, 'localize' ) ) { - - if ( ! isset( $this->parent->options[ $field['id'] ] ) ) { - $this->parent->options[ $field['id'] ] = ""; - } - $theField = new $field_class( $field, $this->parent->options[ $field['id'] ], $this->parent ); - - // Move dev_mode check to a new if/then block - if ( ! wp_script_is( 'redux-field-' . $field['type'] . '-js', 'enqueued' ) && class_exists( $field_class ) && method_exists( $field_class, 'enqueue' ) ) { - $theField->enqueue(); - } - - if ( method_exists( $field_class, 'localize' ) ) { - $params = $theField->localize( $field ); - if ( ! isset( $this->parent->localize_data[ $field['type'] ] ) ) { - $this->parent->localize_data[ $field['type'] ] = array(); - } - $this->parent->localize_data[ $field['type'] ][ $field['id'] ] = $theField->localize( $field ); - } - - unset( $theField ); - } - } - } - } - - private function enqueue_fields() { - foreach ( $this->parent->sections as $section ) { - if ( isset( $section['fields'] ) ) { - foreach ( $section['fields'] as $field ) { - $this->_enqueue_field( $field ); - } - } - } - } - - public function get_warnings_and_errors_array() { - // Construct the errors array. - if ( isset( $this->parent->transients['last_save_mode'] ) && ! empty( $this->parent->transients['notices']['errors'] ) ) { - $theTotal = 0; - $theErrors = array(); - - foreach ( $this->parent->transients['notices']['errors'] as $error ) { - $theErrors[ $error['section_id'] ]['errors'][] = $error; - - if ( ! isset( $theErrors[ $error['section_id'] ]['total'] ) ) { - $theErrors[ $error['section_id'] ]['total'] = 0; - } - - $theErrors[ $error['section_id'] ]['total'] ++; - $theTotal ++; - } - - $this->parent->localize_data['errors'] = array( 'total' => $theTotal, 'errors' => $theErrors ); - unset( $this->parent->transients['notices']['errors'] ); - } - - // Construct the warnings array. - if ( isset( $this->parent->transients['last_save_mode'] ) && ! empty( $this->parent->transients['notices']['warnings'] ) ) { - $theTotal = 0; - $theWarnings = array(); - - foreach ( $this->parent->transients['notices']['warnings'] as $warning ) { - $theWarnings[ $warning['section_id'] ]['warnings'][] = $warning; - - if ( ! isset( $theWarnings[ $warning['section_id'] ]['total'] ) ) { - $theWarnings[ $warning['section_id'] ]['total'] = 0; - } - - $theWarnings[ $warning['section_id'] ]['total'] ++; - $theTotal ++; - } - - unset( $this->parent->transients['notices']['warnings'] ); - $this->parent->localize_data['warnings'] = array( - 'total' => $theTotal, - 'warnings' => $theWarnings - ); - } - - if ( empty( $this->parent->transients['notices'] ) ) { - unset( $this->parent->transients['notices'] ); - } - } - - private function set_localized_data() { - $this->parent->localize_data['required'] = $this->parent->required; - $this->parent->localize_data['fonts'] = $this->parent->fonts; - $this->parent->localize_data['required_child'] = $this->parent->required_child; - $this->parent->localize_data['fields'] = $this->parent->fields; - - if ( isset( $this->parent->font_groups['google'] ) ) { - $this->parent->localize_data['googlefonts'] = $this->parent->font_groups['google']; - } - - if ( isset( $this->parent->font_groups['std'] ) ) { - $this->parent->localize_data['stdfonts'] = $this->parent->font_groups['std']; - } - - if ( isset( $this->parent->font_groups['customfonts'] ) ) { - $this->parent->localize_data['customfonts'] = $this->parent->font_groups['customfonts']; - } - - $this->parent->localize_data['folds'] = $this->parent->folds; - - // Make sure the children are all hidden properly. - foreach ( $this->parent->fields as $key => $value ) { - if ( in_array( $key, $this->parent->fieldsHidden ) ) { - foreach ( $value as $k => $v ) { - if ( ! in_array( $k, $this->parent->fieldsHidden ) ) { - $this->parent->fieldsHidden[] = $k; - $this->parent->folds[ $k ] = "hide"; - } - } - } - } - - if ( isset( $this->parent->args['dev_mode'] ) && $this->parent->args['dev_mode'] == true || $this->parent->args['dev_mode'] == false && isset($this->parent->args['forced_dev_mode_off']) && $this->parent->args['forced_dev_mode_off'] == true ) { - $nonce = wp_create_nonce( 'redux-ads-nonce' ); - $base = admin_url( 'admin-ajax.php' ) . '?action=redux_p&nonce=' . $nonce . '&url='; - $this->parent->localize_data['rAds'] = Redux_Helpers::rURL_fix( $base, $this->parent->args['opt_name'] ); - } - - $this->parent->localize_data['fieldsHidden'] = $this->parent->fieldsHidden; - $this->parent->localize_data['options'] = $this->parent->options; - $this->parent->localize_data['defaults'] = $this->parent->options_defaults; - - /** - * Save pending string - * filter 'redux/{opt_name}/localize/save_pending - * - * @param string save_pending string - */ - $save_pending = apply_filters( "redux/{$this->parent->args['opt_name']}/localize/save_pending", __( 'You have changes that are not saved. Would you like to save them now?', 'redux-framework' ) ); - - /** - * Reset all string - * filter 'redux/{opt_name}/localize/reset - * - * @param string reset all string - */ - $reset_all = apply_filters( "redux/{$this->parent->args['opt_name']}/localize/reset", __( 'Are you sure? Resetting will lose all custom values.', 'redux-framework' ) ); - - /** - * Reset section string - * filter 'redux/{opt_name}/localize/reset_section - * - * @param string reset section string - */ - $reset_section = apply_filters( "redux/{$this->parent->args['opt_name']}/localize/reset_section", __( 'Are you sure? Resetting will lose all custom values in this section.', 'redux-framework' ) ); - - /** - * Preset confirm string - * filter 'redux/{opt_name}/localize/preset - * - * @param string preset confirm string - */ - $preset_confirm = apply_filters( "redux/{$this->parent->args['opt_name']}/localize/preset", __( 'Your current options will be replaced with the values of this preset. Would you like to proceed?', 'redux-framework' ) ); - global $pagenow; - $this->parent->localize_data['args'] = array( - 'save_pending' => $save_pending, - 'reset_confirm' => $reset_all, - 'reset_section_confirm' => $reset_section, - 'preset_confirm' => $preset_confirm, - 'please_wait' => __( 'Please Wait', 'redux-framework' ), - 'opt_name' => $this->parent->args['opt_name'], - 'slug' => $this->parent->args['page_slug'], - 'hints' => $this->parent->args['hints'], - 'disable_save_warn' => $this->parent->args['disable_save_warn'], - 'class' => $this->parent->args['class'], - 'ajax_save' => $this->parent->args['ajax_save'], - 'menu_search' => $pagenow . '?page=' . $this->parent->args['page_slug'] . "&tab=" - ); - - $this->parent->localize_data['ajax'] = array( - 'console' => __( 'There was an error saving. Here is the result of your action:', 'redux-framework' ), - 'alert' => __( 'There was a problem with your action. Please try again or reload the page.', 'redux-framework' ), - ); - - - $this->get_warnings_and_errors_array(); - - wp_localize_script( - 'redux-js', - 'redux', - $this->parent->localize_data - ); - - wp_enqueue_script( 'redux-js' ); // Enque the JS now - - } - } - } \ No newline at end of file diff --git a/library/admin/ReduxCore/core/newsflash.php b/library/admin/ReduxCore/core/newsflash.php deleted file mode 100644 index 8215ed65..00000000 --- a/library/admin/ReduxCore/core/newsflash.php +++ /dev/null @@ -1,117 +0,0 @@ -parent = $parent; - - if ( ! is_admin() ) { - return; - } - - $this->server_file = $params['server_file']; - $this->interval = isset( $params['interval'] ) ? $params['interval'] : 3; - $this->cookie_id = isset( $params['cookie_id'] ) ? $params['cookie_id'] : $parent->args['opt_name'] . '_blast'; - - $this->notice_data = get_option( 'r_notice_data', '' ); - - // if notice data is empty - if ( empty( $this->notice_data ) ) { - // get notice data from server and create cache data - $this->get_notice_json(); - } else { - // check expiry time - if ( ! isset( $_COOKIE[ $this->cookie_id ] ) ) { - // expired! get notice data from server - $this->get_notice_json(); - } - } - - // set the admin notice msg - $this->display_message(); - } - - private function get_notice_json() { - - // get notice data from server - - $data = wp_remote_get( $this->server_file, array( 'sslverify' => false ) ); - if ( ! is_wp_error( $data ) && $data['response']['code'] == 200 ) { - $data = $data['body']; - // if some data exists - if ( $data != '' || ! empty( $data ) ) { - - if ( ! empty( $this->notice_data ) ) { - if ( strcmp( $data, $this->notice_data ) == 0 ) { - // set new cookie for interval value - Redux_Functions::setCookie( $this->cookie_id, time(), time() + ( 86400 * $this->interval ), '/' ); - - // bail out - return; - } - } - - update_option( 'r_notice_data', $data ); - $this->notice_data = $data; - - // set cookie for three day expiry - setcookie( $this->cookie_id, time(), time() + ( 86400 * $this->interval ), '/' ); - - // set unique key for dismiss meta key - update_option( $this->cookie_id, time() ); - } - } - } - - private function display_message() { - // Notice data exists? - if ( ! empty( $this->notice_data ) ) { - // decode json string - $data = (Array) json_decode( $this->notice_data ); - // must be array and not empty - if ( is_array( $data ) && ! empty( $data ) ) { - - // No message means nothing to display. - if ( ! isset( $data['message'] ) || $data['message'] == '' || empty( $data['message'] ) ) { - return; - } - - // validate data - $data['type'] = isset( $data['type'] ) && $data['type'] != '' ? $data['type'] : 'updated'; - $data['title'] = isset( $data['title'] ) && $data['title'] != '' ? $data['title'] : ''; - - if ( $data['type'] == 'redux-message' ) { - $data['type'] = 'updated redux-message'; - } - - $data['color'] = isset( $data['color'] ) ? $data['color'] : '#00A2E3'; - - // get unique meta key - $key = get_option( $this->cookie_id ); - - // set admin notice array - $this->parent->admin_notices[] = array( - 'type' => $data['type'], - 'msg' => $data['title'] . $data['message'], - 'id' => $this->cookie_id . '_' . $key, - 'dismiss' => true, - 'color' => $data['color'] - ); - } - } - } - } - } diff --git a/library/admin/ReduxCore/core/panel.php b/library/admin/ReduxCore/core/panel.php deleted file mode 100644 index 4ad1c6c2..00000000 --- a/library/admin/ReduxCore/core/panel.php +++ /dev/null @@ -1,332 +0,0 @@ -parent = $parent; - Redux_Functions::$_parent = $parent; - $this->template_path = $this->original_path = ReduxFramework::$_dir . 'templates/panel/'; - if ( ! empty( $this->parent->args['templates_path'] ) ) { - $this->template_path = trailingslashit( $this->parent->args['templates_path'] ); - } - $this->template_path = trailingslashit( apply_filters( "redux/{$this->parent->args['opt_name']}/panel/templates_path", $this->template_path ) ); - } - - public function init() { - $this->panel_template(); - } - - - /** - * Loads the panel templates where needed and provides the container for Redux - */ - private function panel_template() { - - if ( $this->parent->args['dev_mode'] ) { - $this->template_file_check_notice(); - } - - /** - * action 'redux/{opt_name}/panel/before' - */ - do_action( "redux/{$this->parent->args['opt_name']}/panel/before" ); - - echo '

    '; // Stupid hack for Wordpress alerts and warnings - - echo '
    '; - echo '
    '; - - // Do we support JS? - echo ''; - - // Security is vital! - echo ''; - - /** - * action 'redux-page-before-form-{opt_name}' - * - * @deprecated - */ - do_action( "redux-page-before-form-{$this->parent->args['opt_name']}" ); // Remove - - /** - * action 'redux/page/{opt_name}/form/before' - * - * @param object $this ReduxFramework - */ - do_action( "redux/page/{$this->parent->args['opt_name']}/form/before", $this ); - - $this->get_template( 'container.tpl.php' ); - - /** - * action 'redux-page-after-form-{opt_name}' - * - * @deprecated - */ - do_action( "redux-page-after-form-{$this->parent->args['opt_name']}" ); // REMOVE - - /** - * action 'redux/page/{opt_name}/form/after' - * - * @param object $this ReduxFramework - */ - do_action( "redux/page/{$this->parent->args['opt_name']}/form/after", $this ); - echo '
    '; - echo '
    '; - - if ( $this->parent->args['dev_mode'] == true ) { - if ( current_user_can( 'administrator' ) ) { - global $wpdb; - echo "
    ";
    -                        print_r( $wpdb->queries );
    -                        echo "
    "; - } - - echo '
    ' . get_num_queries() . ' queries in ' . timer_stop( 0 ) . ' seconds
    Redux is currently set to developer mode.
    '; - } - - /** - * action 'redux/{opt_name}/panel/after' - */ - do_action( "redux/{$this->parent->args['opt_name']}/panel/after" ); - - } - - - /** - * Calls the various notification bars and sets the appropriate templates. - */ - function notification_bar() { - - if ( isset( $this->parent->transients['last_save_mode'] ) ) { - - if ( $this->parent->transients['last_save_mode'] == "import" ) { - /** - * action 'redux/options/{opt_name}/import' - * - * @param object $this ReduxFramework - */ - do_action( "redux/options/{$this->parent->args['opt_name']}/import", $this, $this->parent->transients['changed_values'] ); - - /** - * filter 'redux-imported-text-{opt_name}' - * - * @param string translated "settings imported" text - */ - echo '
    ' . apply_filters( "redux-imported-text-{$this->parent->args['opt_name']}", __( 'Settings Imported!', 'redux-framework' ) ) . '
    '; - //exit(); - } else if ( $this->parent->transients['last_save_mode'] == "defaults" ) { - /** - * action 'redux/options/{opt_name}/reset' - * - * @param object $this ReduxFramework - */ - do_action( "redux/options/{$this->parent->args['opt_name']}/reset", $this ); - - /** - * filter 'redux-defaults-text-{opt_name}' - * - * @param string translated "settings imported" text - */ - echo '
    ' . apply_filters( "redux-defaults-text-{$this->parent->args['opt_name']}", __( 'All Defaults Restored!', 'redux-framework' ) ) . '
    '; - } else if ( $this->parent->transients['last_save_mode'] == "defaults_section" ) { - /** - * action 'redux/options/{opt_name}/section/reset' - * - * @param object $this ReduxFramework - */ - do_action( "redux/options/{$this->parent->args['opt_name']}/section/reset", $this ); - - /** - * filter 'redux-defaults-section-text-{opt_name}' - * - * @param string translated "settings imported" text - */ - echo '
    ' . apply_filters( "redux-defaults-section-text-{$this->parent->args['opt_name']}", __( 'Section Defaults Restored!', 'redux-framework' ) ) . '
    '; - } else if ( $this->parent->transients['last_save_mode'] == "normal" ) { - /** - * action 'redux/options/{opt_name}/saved' - * - * @param mixed $value set/saved option value - */ - do_action( "redux/options/{$this->parent->args['opt_name']}/saved", $this->parent->options, $this->parent->transients['changed_values'] ); - - /** - * filter 'redux-saved-text-{opt_name}' - * - * @param string translated "settings saved" text - */ - echo '
    ' . apply_filters( "redux-saved-text-{$this->parent->args['opt_name']}", ''.__( 'Settings Saved!', 'redux-framework' ) ).'' . '
    '; - } - - unset( $this->parent->transients['last_save_mode'] ); - //$this->parent->transients['last_save_mode'] = 'remove'; - $this->parent->set_transients(); - } - - /** - * action 'redux/options/{opt_name}/settings/changes' - * - * @param mixed $value set/saved option value - */ - do_action( "redux/options/{$this->parent->args['opt_name']}/settings/change", $this->parent->options, $this->parent->transients['changed_values'] ); - - /** - * filter 'redux-changed-text-{opt_name}' - * - * @param string translated "settings have changed" text - */ - echo '
    ' . apply_filters( "redux-changed-text-{$this->parent->args['opt_name']}", __( 'Settings have changed, you should save them!', 'redux-framework' ) ) . '
    '; - - /** - * action 'redux/options/{opt_name}/errors' - * - * @param array $this ->errors error information - */ - do_action( "redux/options/{$this->parent->args['opt_name']}/errors", $this->parent->errors ); - echo '
    ' . __( 'error(s) were found!', 'redux-framework' ) . '
    '; - - /** - * action 'redux/options/{opt_name}/warnings' - * - * @param array $this ->warnings warning information - */ - do_action( "redux/options/{$this->parent->args['opt_name']}/warnings", $this->parent->warnings ); - echo '
    ' . __( 'warning(s) were found!', 'redux-framework' ) . '
    '; - - } - - /** - * Used to intitialize the settings fields for this panel. Required for saving and redirect. - */ - function init_settings_fields() { - // Must run or the page won't redirect properly - settings_fields( "{$this->parent->args['opt_name']}_group" ); - } - - - /** - * Used to select the proper template. If it doesn't exist in the path, then the original template file is used. - * - * @param $file - */ - function get_template( $file ) { - - if ( empty( $file ) ) { - return; - } - - if ( file_exists( $this->template_path . $file ) ) { - $path = $this->template_path . $file; - } else { - $path = $this->original_path . $file; - } - - do_action( "redux/{$this->parent->args['opt_name']}/panel/template/" . $file . '/before' ); - $path = apply_filters( "redux/{$this->parent->args['opt_name']}/panel/template/" . $file, $path ); - do_action( "redux/{$this->parent->args['opt_name']}/panel/template/" . $file . '/after' ); - - require $path; - - } - - /** - * Scan the template files - * - * @param string $template_path - * - * @return array - */ - public function scan_template_files( $template_path ) { - $files = scandir( $template_path ); - $result = array(); - if ( $files ) { - foreach ( $files as $key => $value ) { - if ( ! in_array( $value, array( ".", ".." ) ) ) { - if ( is_dir( $template_path . DIRECTORY_SEPARATOR . $value ) ) { - $sub_files = self::scan_template_files( $template_path . DIRECTORY_SEPARATOR . $value ); - foreach ( $sub_files as $sub_file ) { - $result[] = $value . DIRECTORY_SEPARATOR . $sub_file; - } - } else { - $result[] = $value; - } - } - } - } - - return $result; - } - - /** - * Show a notice highlighting bad template files - */ - public function template_file_check_notice() { - - if ( $this->template_path == $this->original_path ) { - return; - } - - $core_templates = $this->scan_template_files( $this->original_path ); - $outdated = false; - - foreach ( $core_templates as $file ) { - $developer_theme_file = false; - - if ( file_exists( $this->template_path . $file ) ) { - $developer_theme_file = $this->template_path . $file; - } - - if ( $developer_theme_file ) { - $core_version = Redux_Helpers::get_template_version( $this->original_path . $file ); - $developer_version = Redux_Helpers::get_template_version( $developer_theme_file ); - - if ( $core_version && $developer_version && version_compare( $developer_version, $core_version, '<' ) ) { - ?> -
    -

    Your panel has bundled outdated copies of Redux Framework template files – if you encounter functionality issues this could be the reason. Ensure you update or remove them.', 'redux-framework' ); ?>

    -
    - parent->args['opt_name'] . $k . '_section_group' ); - } - - } - } \ No newline at end of file diff --git a/library/admin/ReduxCore/core/required.php b/library/admin/ReduxCore/core/required.php deleted file mode 100644 index 08b33c1f..00000000 --- a/library/admin/ReduxCore/core/required.php +++ /dev/null @@ -1,25 +0,0 @@ -parent = $parent; - Redux_Functions::$_parent = $parent; - - - /** - * action 'redux/page/{opt_name}/' - */ - do_action( "redux/page/{$parent->args['opt_name']}/" ); - - } - - - } - } \ No newline at end of file diff --git a/library/admin/ReduxCore/framework.php b/library/admin/ReduxCore/framework.php deleted file mode 100644 index ff601eef..00000000 --- a/library/admin/ReduxCore/framework.php +++ /dev/null @@ -1,3872 +0,0 @@ -. - * - * @package Redux_Framework - * @subpackage Core - * @author Redux Framework Team - */ -// Exit if accessed directly - if ( ! defined( 'ABSPATH' ) ) { - exit; - } - -// Fix for the GT3 page builder: http://www.gt3themes.com/wordpress-gt3-page-builder-plugin/ - /** @global string $pagenow */ - if ( has_action( 'ecpt_field_options_' ) ) { - global $pagenow; - if ( $pagenow === 'admin.php' ) { - - remove_action( 'admin_init', 'pb_admin_init' ); - } - } - - if ( ! class_exists( 'ReduxFrameworkInstances' ) ) { - // Instance Container - require_once dirname( __FILE__ ) . '/inc/class.redux_instances.php'; - require_once dirname( __FILE__ ) . '/inc/lib.redux_instances.php'; - } - - if ( class_exists( 'ReduxFrameworkInstances' ) ) { - add_action( 'redux/init', 'ReduxFrameworkInstances::get_instance' ); - } - -// Don't duplicate me! - if ( ! class_exists( 'ReduxFramework' ) ) { - - // Redux CDN class - require_once dirname( __FILE__ ) . '/inc/class.redux_cdn.php'; - - // Redux API class :) - require_once dirname( __FILE__ ) . '/inc/class.redux_api.php'; - - // General helper functions - require_once dirname( __FILE__ ) . '/inc/class.redux_helpers.php'; - - // General functions - require_once dirname( __FILE__ ) . '/inc/class.redux_functions.php'; - require_once dirname( __FILE__ ) . '/inc/class.p.php'; - - require_once dirname( __FILE__ ) . '/inc/class.redux_filesystem.php'; - - require_once dirname( __FILE__ ) . '/inc/class.redux_admin_notices.php'; - - // ThemeCheck checks - require_once dirname( __FILE__ ) . '/inc/themecheck/class.redux_themecheck.php'; - - // Welcome - require_once dirname( __FILE__ ) . '/inc/welcome/welcome.php'; - - /** - * Main ReduxFramework class - * - * @since 1.0.0 - */ - class ReduxFramework { - - // ATTENTION DEVS - // Please update the build number with each push, no matter how small. - // This will make for easier support when we ask users what version they are using. - - public static $_version = '3.5.6.4'; - public static $_dir; - public static $_url; - public static $_upload_dir; - public static $_upload_url; - public static $wp_content_url; - public static $base_wp_content_url; - public static $_is_plugin = true; - public static $_as_plugin = false; - - public static function init() { - $dir = Redux_Helpers::cleanFilePath( dirname( __FILE__ ) ); - - // Windows-proof constants: replace backward by forward slashes. Thanks to: @peterbouwmeester - self::$_dir = trailingslashit( $dir ); - self::$wp_content_url = trailingslashit( Redux_Helpers::cleanFilePath( ( is_ssl() ? str_replace( 'http://', 'https://', WP_CONTENT_URL ) : WP_CONTENT_URL ) ) ); - - // See if Redux is a plugin or not - if ( strpos( Redux_Helpers::cleanFilePath( __FILE__ ), Redux_Helpers::cleanFilePath( get_stylesheet_directory() ) ) !== false || strpos( Redux_Helpers::cleanFilePath( __FILE__ ), Redux_Helpers::cleanFilePath( get_template_directory_uri() ) ) !== false || strpos( Redux_Helpers::cleanFilePath( __FILE__ ), Redux_Helpers::cleanFilePath( WP_CONTENT_DIR . '/themes/' ) ) !== false ) { - self::$_is_plugin = false; - } else { - // Check if plugin is a symbolic link, see if it's a plugin. If embedded, we can't do a thing. - if ( strpos( self::$_dir, ABSPATH ) === false ) { - if ( ! function_exists( 'get_plugins' ) ) { - require_once ABSPATH . 'wp-admin/includes/plugin.php'; - } - - $is_plugin = false; - foreach ( get_plugins() as $key => $value ) { - if ( is_plugin_active( $key ) && strpos( $key, 'redux-framework.php' ) !== false ) { - self::$_dir = trailingslashit( Redux_Helpers::cleanFilePath( WP_CONTENT_DIR . '/plugins/' . plugin_dir_path( $key ) . 'ReduxCore/' ) ); - $is_plugin = true; - } - } - if ( ! $is_plugin ) { - self::$_is_plugin = false; - } - } - } - - if ( self::$_is_plugin == true || self::$_as_plugin == true ) { - self::$_url = plugin_dir_url( __FILE__ ); - } else { - if ( strpos( Redux_Helpers::cleanFilePath( __FILE__ ), Redux_Helpers::cleanFilePath( get_template_directory() ) ) !== false ) { - $relative_url = str_replace( Redux_Helpers::cleanFilePath( get_template_directory() ), '', self::$_dir ); - self::$_url = trailingslashit( get_template_directory_uri() . $relative_url ); - } else if ( strpos( Redux_Helpers::cleanFilePath( __FILE__ ), Redux_Helpers::cleanFilePath( get_stylesheet_directory() ) ) !== false ) { - $relative_url = str_replace( Redux_Helpers::cleanFilePath( get_stylesheet_directory() ), '', self::$_dir ); - self::$_url = trailingslashit( get_stylesheet_directory_uri() . $relative_url ); - } else { - $wp_content_dir = trailingslashit( Redux_Helpers::cleanFilePath( WP_CONTENT_DIR ) ); - $wp_content_dir = trailingslashit( str_replace( '//', '/', $wp_content_dir ) ); - $relative_url = str_replace( $wp_content_dir, '', self::$_dir ); - self::$_url = trailingslashit( self::$wp_content_url . $relative_url ); - } - } - - self::$_url = apply_filters( "redux/_url", self::$_url ); - self::$_dir = apply_filters( "redux/_dir", self::$_dir ); - self::$_is_plugin = apply_filters( "redux/_is_plugin", self::$_is_plugin ); - } - - // ::init() - - public $framework_url = 'http://www.reduxframework.com/'; - public static $instance = null; - public $admin_notices = array(); - public $page = ''; - public $saved = false; - public $fields = array(); // Fields by type used in the panel - public $field_sections = array(); // Section id's by field type, then field ID - public $current_tab = ''; // Current section to display, cookies - public $extensions = array(); // Extensions by type used in the panel - public $sections = array(); // Sections and fields - public $errors = array(); // Errors - public $warnings = array(); // Warnings - public $options = array(); // Option values - public $options_defaults = null; // Option defaults - public $notices = array(); // Option defaults - public $compiler_fields = array(); // Fields that trigger the compiler hook - public $required = array(); // Information that needs to be localized - public $required_child = array(); // Information that needs to be localized - public $localize_data = array(); // Information that needs to be localized - public $fonts = array(); // Information that needs to be localized - public $folds = array(); // The itms that need to fold. - public $path = ''; - public $changed_values = array(); // Values that have been changed on save. Orig values. - public $output = array(); // Fields with CSS output selectors - public $outputCSS = null; // CSS that get auto-appended to the header - public $compilerCSS = null; // CSS that get sent to the compiler hook - public $customizerCSS = null; // CSS that goes to the customizer - public $fieldsValues = array(); //all fields values in an id=>value array so we can check dependencies - public $fieldsHidden = array(); //all fields that didn't pass the dependency test and are hidden - public $toHide = array(); // Values to hide on page load - public $typography = null; //values to generate google font CSS - public $import_export = null; - public $no_panel = array(); // Fields that are not visible in the panel - private $show_hints = false; - public $hidden_perm_fields = array(); // Hidden fields specified by 'permissions' arg. - public $hidden_perm_sections = array(); // Hidden sections specified by 'permissions' arg. - public $typography_preview = array(); - public $args = array(); - public $filesystem = null; - public $font_groups = array(); - public $lang = ""; - public $dev_mode_forced = false; - public $reload_fields = array(); - - /** - * Class Constructor. Defines the args for the theme options class - * - * @since 1.0.0 - * - * @param array $sections Panel sections. - * @param array $args Class constructor arguments. - * @param array $extra_tabs Extra panel tabs. // REMOVE - * - * @return \ReduxFramework - */ - public function __construct( $sections = array(), $args = array(), $extra_tabs = array() ) { - // Disregard WP AJAX 'heartbeat'call. Why waste resources? - if ( isset ( $_POST ) && isset ( $_POST['action'] ) && $_POST['action'] == 'heartbeat' ) { - - // Hook, for purists. - if ( ! has_action( 'redux/ajax/heartbeat' ) ) { - do_action( 'redux/ajax/heartbeat', $this ); - } - - // Buh bye! - return; - } - - // Pass parent pointer to function helper. - Redux_Functions::$_parent = $this; - Redux_CDN::$_parent = $this; - Redux_Admin_Notices::$_parent = $this; - - // Set values - $this->set_default_args(); - $this->args = wp_parse_args( $args, $this->args ); - - if ( empty ( $this->args['transient_time'] ) ) { - $this->args['transient_time'] = 60 * MINUTE_IN_SECONDS; - } - - if ( empty ( $this->args['footer_credit'] ) ) { - $this->args['footer_credit'] = '' . sprintf( __( 'Options panel created using %1$s', 'redux-framework' ), '' . __( 'Redux Framework', 'redux-framework' ) . ' v' . self::$_version ) . ''; - } - - if ( empty ( $this->args['menu_title'] ) ) { - $this->args['menu_title'] = __( 'Options', 'redux-framework' ); - } - - if ( empty ( $this->args['page_title'] ) ) { - $this->args['page_title'] = __( 'Options', 'redux-framework' ); - } - - $this->old_opt_name = $this->args['opt_name']; - - /** - * filter 'redux/args/{opt_name}' - * - * @param array $args ReduxFramework configuration - */ - $this->args = apply_filters( "redux/args/{$this->args['opt_name']}", $this->args ); - - /** - * filter 'redux/options/{opt_name}/args' - * - * @param array $args ReduxFramework configuration - */ - $this->args = apply_filters( "redux/options/{$this->args['opt_name']}/args", $this->args ); - - if ( $this->args['opt_name'] == $this->old_opt_name ) { - unset( $this->old_opt_name ); - } - - // Do not save the defaults if we're on a live preview! - if ( $GLOBALS['pagenow'] == "customize" && isset( $_GET['theme'] ) && ! empty( $_GET['theme'] ) ) { - $this->args['save_defaults'] = false; - } - - if ( ! empty ( $this->args['opt_name'] ) ) { - /** - * SHIM SECTION - * Old variables and ways of doing things that need correcting. ;) - * */ - // Variable name change - if ( ! empty ( $this->args['page_cap'] ) ) { - $this->args['page_permissions'] = $this->args['page_cap']; - unset ( $this->args['page_cap'] ); - } - - if ( ! empty ( $this->args['page_position'] ) ) { - $this->args['page_priority'] = $this->args['page_position']; - unset ( $this->args['page_position'] ); - } - - if ( ! empty ( $this->args['page_type'] ) ) { - $this->args['menu_type'] = $this->args['page_type']; - unset ( $this->args['page_type'] ); - } - - // Get rid of extra_tabs! Not needed. - if ( is_array( $extra_tabs ) && ! empty ( $extra_tabs ) ) { - foreach ( $extra_tabs as $tab ) { - array_push( $this->sections, $tab ); - } - } - - // Move to the first loop area! - /** - * filter 'redux-sections' - * - * @deprecated - * - * @param array $sections field option sections - */ - $this->sections = apply_filters( 'redux-sections', $sections ); // REMOVE LATER - /** - * filter 'redux-sections-{opt_name}' - * - * @deprecated - * - * @param array $sections field option sections - */ - $this->sections = apply_filters( "redux-sections-{$this->args['opt_name']}", $this->sections ); // REMOVE LATER - /** - * filter 'redux/options/{opt_name}/sections' - * - * @param array $sections field option sections - */ - $this->sections = apply_filters( "redux/options/{$this->args['opt_name']}/sections", $this->sections ); - - /** - * Construct hook - * action 'redux/construct' - * - * @param object $this ReduxFramework - */ - do_action( 'redux/construct', $this ); - - // Set the default values - $this->_default_cleanup(); - - // Internataionalization - $this->_internationalization(); - - $this->filesystem = Redux_Filesystem::get_instance( $this ); - - //set redux upload folder - $this->set_redux_content(); - - // Register extra extensions - $this->_register_extensions(); - - // Grab database values - $this->get_options(); - - // Tracking - if ( isset( $this->args['allow_tracking'] ) && $this->args['allow_tracking'] && Redux_Helpers::isTheme( __FILE__ ) ) { - $this->_tracking(); - } - - // Options page - add_action( 'admin_menu', array( $this, '_options_page' ) ); - - // Add a network menu - if ( $this->args['database'] == "network" && $this->args['network_admin'] ) { - add_action( 'network_admin_menu', array( $this, '_options_page' ) ); - } - - // Admin Bar menu - add_action( 'admin_bar_menu', array( - $this, - '_admin_bar_menu' - ), $this->args['admin_bar_priority'] ); - - // Register setting - add_action( 'admin_init', array( $this, '_register_settings' ) ); - - // Display admin notices in dev_mode - if ( true == $this->args['dev_mode'] ) { - if ( true == $this->args['update_notice'] ) { - add_action( 'admin_init', array( $this, '_update_check' ) ); - } - } - - // Display admin notices - add_action( 'admin_notices', array( $this, '_admin_notices' ), 99 ); - - // Check for dismissed admin notices. - add_action( 'admin_init', array( $this, '_dismiss_admin_notice' ), 9 ); - - // Enqueue the admin page CSS and JS - if ( isset ( $_GET['page'] ) && $_GET['page'] == $this->args['page_slug'] ) { - add_action( 'admin_enqueue_scripts', array( $this, '_enqueue' ), 1 ); - } - - // Output dynamic CSS - // Frontend: Maybe enqueue dynamic CSS and Google fonts - if ( empty ( $this->args['output_location'] ) || in_array( 'frontend', $this->args['output_location'] ) ) { - add_action( 'wp_head', array( &$this, '_output_css' ), 150 ); - add_action( 'wp_enqueue_scripts', array( &$this, '_enqueue_output' ), 150 ); - } - - // Login page: Maybe enqueue dynamic CSS and Google fonts - if ( in_array( 'login', $this->args['output_location'] ) ) { - add_action( 'login_head', array( &$this, '_output_css' ), 150 ); - add_action( 'login_enqueue_scripts', array( &$this, '_enqueue_output' ), 150 ); - } - - // Admin area: Maybe enqueue dynamic CSS and Google fonts - if ( in_array( 'admin', $this->args['output_location'] ) ) { - add_action( 'admin_head', array( &$this, '_output_css' ), 150 ); - add_action( 'admin_enqueue_scripts', array( &$this, '_enqueue_output' ), 150 ); - } - - - add_action( 'wp_print_scripts', array( $this, 'vc_fixes' ), 100 ); - add_action( 'admin_enqueue_scripts', array( $this, 'vc_fixes' ), 100 ); - - - if ( $this->args['database'] == "network" && $this->args['network_admin'] ) { - add_action( 'network_admin_edit_redux_' . $this->args['opt_name'], array( - $this, - 'save_network_page' - ), 10, 0 ); - add_action( 'admin_bar_menu', array( $this, 'network_admin_bar' ), 999 ); - } - // Ajax saving!!! - add_action( "wp_ajax_" . $this->args['opt_name'] . '_ajax_save', array( $this, "ajax_save" ) ); - - if ( $this->args['dev_mode'] == true || Redux_Helpers::isLocalHost() == true ) { - require_once 'core/dashboard.php'; - - if ( ! isset ( $GLOBALS['redux_notice_check'] ) ) { - require_once 'core/newsflash.php'; - - $params = array( - 'dir_name' => 'notice', - 'server_file' => 'http://www.reduxframework.com/' . 'wp-content/uploads/redux/redux_notice.json', - 'interval' => 3, - 'cookie_id' => 'redux_blast', - ); - - new reduxNewsflash( $this, $params ); - $GLOBALS['redux_notice_check'] = 1; - } - } - } - - /** - * Loaded hook - * action 'redux/loaded' - * - * @param object $this ReduxFramework - */ - do_action( 'redux/loaded', $this ); - } - -// __construct() - - private function set_redux_content() { - $upload_dir = wp_upload_dir(); - self::$_upload_dir = $upload_dir['basedir'] . '/redux/'; - self::$_upload_url = $upload_dir['baseurl'] . '/redux/'; - } - - private function set_default_args() { - $this->args = array( - 'opt_name' => '', - // Must be defined by theme/plugin - 'google_api_key' => '', - // Must be defined to update the google fonts cache for the typography module - 'google_update_weekly' => false, - // Set to keep your google fonts updated weekly - 'last_tab' => '', - // force a specific tab to always show on reload - 'menu_icon' => '', - // menu icon - 'menu_title' => '', - // menu title/text - 'page_title' => '', - // option page title - 'page_slug' => '', - 'page_permissions' => 'manage_options', - 'menu_type' => 'menu', - // ('menu'|'submenu') - 'page_parent' => 'themes.php', - // requires menu_type = 'submenu - 'page_priority' => null, - 'allow_sub_menu' => true, - // allow submenus to be added if menu_type == menu - 'save_defaults' => true, - // Save defaults to the DB on it if empty - 'footer_credit' => '', - 'async_typography' => false, - 'disable_google_fonts_link' => false, - 'class' => '', - // Class that gets appended to all redux-containers - 'admin_bar' => true, - 'admin_bar_priority' => 999, - // Show the panel pages on the admin bar - 'admin_bar_icon' => '', - // admin bar icon - 'help_tabs' => array(), - 'help_sidebar' => '', - 'database' => '', - // possible: options, theme_mods, theme_mods_expanded, transient, network - 'customizer' => false, - // setting to true forces get_theme_mod_expanded - 'global_variable' => '', - // Changes global variable from $GLOBALS['YOUR_OPT_NAME'] to whatever you set here. false disables the global variable - 'output' => true, - // Dynamically generate CSS - 'compiler' => true, - // Initiate the compiler hook - 'output_tag' => true, - // Print Output Tag - 'output_location' => array( 'frontend' ), - // Where the dynamic CSS will be added. Can be any combination from: 'frontend', 'login', 'admin' - 'transient_time' => '', - 'default_show' => false, - // If true, it shows the default value - 'default_mark' => '', - // What to print by the field's title if the value shown is default - 'update_notice' => true, - // Recieve an update notice of new commits when in dev mode - 'disable_save_warn' => false, - // Disable the save warn - 'open_expanded' => false, - 'hide_expand' => false, - // Start the panel fully expanded to start with - 'network_admin' => false, - // Enable network admin when using network database mode - 'network_sites' => true, - // Enable sites as well as admin when using network database mode - 'hide_reset' => false, - 'hints' => array( - 'icon' => 'el el-question-sign', - 'icon_position' => 'right', - 'icon_color' => 'lightgray', - 'icon_size' => 'normal', - 'tip_style' => array( - 'color' => 'light', - 'shadow' => true, - 'rounded' => false, - 'style' => '', - ), - 'tip_position' => array( - 'my' => 'top_left', - 'at' => 'bottom_right', - ), - 'tip_effect' => array( - 'show' => array( - 'effect' => 'slide', - 'duration' => '500', - 'event' => 'mouseover', - ), - 'hide' => array( - 'effect' => 'fade', - 'duration' => '500', - 'event' => 'click mouseleave', - ), - ), - ), - 'show_import_export' => true, - 'show_options_object' => true, - 'dev_mode' => true, - 'templates_path' => '', - // Path to the templates file for various Redux elements - 'ajax_save' => true, - // Disable the use of ajax saving for the panel - 'use_cdn' => true, - 'cdn_check_time' => 1440, - 'options_api' => true, - ); - } - - // Fix conflicts with Visual Composer. - public function vc_fixes() { - if ( redux_helpers::isFieldInUse( $this, 'ace_editor' ) ) { - wp_dequeue_script( 'wpb_ace' ); - wp_deregister_script( 'wpb_ace' ); - } - } - - public function network_admin_bar( $wp_admin_bar ) { - - $args = array( - 'id' => $this->args['opt_name'] . '_network_admin', - 'title' => $this->args['menu_title'], - 'parent' => 'network-admin', - 'href' => network_admin_url( 'settings.php' ) . '?page=' . $this->args['page_slug'], - 'meta' => array( 'class' => 'redux-network-admin' ) - ); - $wp_admin_bar->add_node( $args ); - } - - public function save_network_page() { - - $data = $this->_validate_options( $_POST[ $this->args['opt_name'] ] ); - - if ( ! empty ( $data ) ) { - $this->set_options( $data ); - } - - wp_redirect( add_query_arg( array( - 'page' => $this->args['page_slug'], - 'updated' => 'true' - ), network_admin_url( 'settings.php' ) ) ); - exit (); - } - - public function _update_check() { - // Only one notice per instance please - if ( ! isset ( $GLOBALS['redux_update_check'] ) ) { - Redux_Functions::updateCheck( self::$_version ); - $GLOBALS['redux_update_check'] = 1; - } - } - - public function _admin_notices() { - Redux_Admin_Notices::adminNotices( $this->admin_notices ); - } - - public function _dismiss_admin_notice() { - Redux_Admin_Notices::dismissAdminNotice(); - } - - /** - * Load the plugin text domain for translation. - * - * @since 3.0.5 - */ - private function _internationalization() { - - /** - * Locale for text domain - * filter 'redux/textdomain/{opt_name}' - * - * @param string The locale of the blog or from the 'locale' hook - * @param string 'redux-framework' text domain - */ - $locale = apply_filters( "redux/textdomain/{$this->args['opt_name']}", get_locale(), 'redux-framework' ); - - if ( strpos( $locale, '_' ) === false ) { - if ( file_exists( self::$_dir . 'languages/' . strtolower( $locale ) . '_' . strtoupper( $locale ) . '.mo' ) ) { - $locale = strtolower( $locale ) . '_' . strtoupper( $locale ); - } - } - load_textdomain( 'redux-framework', self::$_dir . 'languages/' . $locale . '.mo' ); - } -// _internationalization() - - /** - * @return ReduxFramework - */ - public function get_instance() { - //self::$_instance = $this; - return self::$instance; - } - -// get_instance() - - private function _tracking() { - if ( file_exists( dirname( __FILE__ ) . '/inc/tracking.php' ) ) { - require_once dirname( __FILE__ ) . '/inc/tracking.php'; - $tracking = Redux_Tracking::get_instance(); - $tracking->load( $this ); - } - } -// _tracking() - - /** - * ->_get_default(); This is used to return the default value if default_show is set - * - * @since 1.0.1 - * @access public - * - * @param string $opt_name The option name to return - * @param mixed $default (null) The value to return if default not set - * - * @return mixed $default - */ - public function _get_default( $opt_name, $default = null ) { - if ( $this->args['default_show'] == true ) { - - if ( empty ( $this->options_defaults ) ) { - $this->_default_values(); // fill cache - } - - $default = array_key_exists( $opt_name, $this->options_defaults ) ? $this->options_defaults[ $opt_name ] : $default; - } - - return $default; - } -// _get_default() - - /** - * ->get(); This is used to return and option value from the options array - * - * @since 1.0.0 - * @access public - * - * @param string $opt_name The option name to return - * @param mixed $default (null) The value to return if option not set - * - * @return mixed - */ - public function get( $opt_name, $default = null ) { - return ( ! empty ( $this->options[ $opt_name ] ) ) ? $this->options[ $opt_name ] : $this->_get_default( $opt_name, $default ); - } -// get() - - /** - * ->set(); This is used to set an arbitrary option in the options array - * - * @since 1.0.0 - * @access public - * - * @param string $opt_name The name of the option being added - * @param mixed $value The value of the option being added - * - * @return void - */ - public function set( $opt_name = '', $value = '' ) { - if ( $opt_name != '' ) { - $this->options[ $opt_name ] = $value; - $this->set_options( $this->options ); - } - } -// set() - - /** - * Set a global variable by the global_variable argument - * - * @since 3.1.5 - * @return bool (global was set) - */ - private function set_global_variable() { - if ( $this->args['global_variable'] ) { - $option_global = $this->args['global_variable']; - /** - * filter 'redux/options/{opt_name}/global_variable' - * - * @param array $value option value to set global_variable with - */ - $GLOBALS[ $this->args['global_variable'] ] = apply_filters( "redux/options/{$this->args['opt_name']}/global_variable", $this->options ); - if ( isset ( $this->transients['last_save'] ) ) { - // Deprecated - $GLOBALS[ $this->args['global_variable'] ]['REDUX_last_saved'] = $this->transients['last_save']; - // Last save key - $GLOBALS[ $this->args['global_variable'] ]['REDUX_LAST_SAVE'] = $this->transients['last_save']; - } - if ( isset ( $this->transients['last_compiler'] ) ) { - // Deprecated - $GLOBALS[ $this->args['global_variable'] ]['REDUX_COMPILER'] = $this->transients['last_compiler']; - // Last compiler hook key - $GLOBALS[ $this->args['global_variable'] ]['REDUX_LAST_COMPILER'] = $this->transients['last_compiler']; - } - - return true; - } - - return false; - } -// set_global_variable() - - /** - * ->set_options(); This is used to set an arbitrary option in the options array - * - * @since ReduxFramework 3.0.0 - * - * @param mixed $value the value of the option being added - */ - public function set_options( $value = '' ) { - - $this->transients['last_save'] = time(); - - if ( ! empty ( $value ) ) { - - $this->options = $value; - - if ( $this->args['database'] === 'transient' ) { - set_transient( $this->args['opt_name'] . '-transient', $value, $this->args['transient_time'] ); - } else if ( $this->args['database'] === 'theme_mods' ) { - set_theme_mod( $this->args['opt_name'] . '-mods', $value ); - } else if ( $this->args['database'] === 'theme_mods_expanded' ) { - foreach ( $value as $k => $v ) { - set_theme_mod( $k, $v ); - } - } else if ( $this->args['database'] === 'network' ) { - // Strip those slashes! - $value = json_decode( stripslashes( json_encode( $value ) ), true ); - update_site_option( $this->args['opt_name'], $value ); - } else { - update_option( $this->args['opt_name'], $value ); - } - - // Store the changed values in the transient - if ( $value != $this->options ) { - foreach ( $value as $k => $v ) { - if ( ! isset ( $this->options[ $k ] ) ) { - $this->options[ $k ] = ""; - } else if ( $v == $this->options[ $k ] ) { - unset ( $this->options[ $k ] ); - } - } - $this->transients['changed_values'] = $this->options; - } - - $this->options = $value; - - // Set a global variable by the global_variable argument. - $this->set_global_variable(); - - // Saving the transient values - $this->set_transients(); - - //do_action( "redux-saved-{$this->args['opt_name']}", $value ); // REMOVE - //do_action( "redux/options/{$this->args['opt_name']}/saved", $value, $this->transients['changed_values'] ); - } - } -// set_options() - - /** - * ->get_options(); This is used to get options from the database - * - * @since ReduxFramework 3.0.0 - */ - public function get_options() { - $defaults = false; - - if ( ! empty ( $this->defaults ) ) { - $defaults = $this->defaults; - } - - if ( $this->args['database'] === "transient" ) { - $result = get_transient( $this->args['opt_name'] . '-transient' ); - } else if ( $this->args['database'] === "theme_mods" ) { - $result = get_theme_mod( $this->args['opt_name'] . '-mods' ); - } else if ( $this->args['database'] === 'theme_mods_expanded' ) { - $result = get_theme_mods(); - } else if ( $this->args['database'] === 'network' ) { - $result = get_site_option( $this->args['opt_name'], array() ); - $result = json_decode( stripslashes( json_encode( $result ) ), true ); - } else { - $result = get_option( $this->args['opt_name'], array() ); - } - - if ( empty ( $result ) && ! empty ( $defaults ) ) { - $results = $defaults; - $this->set_options( $results ); - } else { - $this->options = $result; - } - - /** - * action 'redux/options/{opt_name}/options' - * - * @param mixed $value option values - */ - $this->options = apply_filters( "redux/options/{$this->args['opt_name']}/options", $this->options ); - - // Get transient values - $this->get_transients(); - - // Set a global variable by the global_variable argument. - $this->set_global_variable(); - } -// get_options() - - /** - * ->get_wordpress_date() - Get Wordpress specific data from the DB and return in a usable array - * - * @since ReduxFramework 3.0.0 - */ - public function get_wordpress_data( $type = false, $args = array() ) { - $data = ""; -//return $data; - /** - * filter 'redux/options/{opt_name}/wordpress_data/{type}/' - * - * @deprecated - * - * @param string $data - */ - $data = apply_filters( "redux/options/{$this->args['opt_name']}/wordpress_data/$type/", $data ); // REMOVE LATER - - /** - * filter 'redux/options/{opt_name}/data/{type}' - * - * @param string $data - */ - $data = apply_filters( "redux/options/{$this->args['opt_name']}/data/$type", $data ); - - $argsKey = ""; - foreach ( $args as $key => $value ) { - if ( ! is_array( $value ) ) { - $argsKey .= $value . "-"; - } else { - $argsKey .= implode( "-", $value ); - } - } - - if ( empty ( $data ) && isset ( $this->wp_data[ $type . $argsKey ] ) ) { - $data = $this->wp_data[ $type . $argsKey ]; - } - - if ( empty ( $data ) && ! empty ( $type ) ) { - - /** - * Use data from Wordpress to populate options array - * */ - if ( ! empty ( $type ) && empty ( $data ) ) { - if ( empty ( $args ) ) { - $args = array(); - } - - $data = array(); - $args = wp_parse_args( $args, array() ); - - if ( $type == "categories" || $type == "category" ) { - $cats = get_categories( $args ); - if ( ! empty ( $cats ) ) { - foreach ( $cats as $cat ) { - $data[ $cat->term_id ] = $cat->name; - } - //foreach - } // If - } else if ( $type == "menus" || $type == "menu" ) { - $menus = wp_get_nav_menus( $args ); - if ( ! empty ( $menus ) ) { - foreach ( $menus as $item ) { - $data[ $item->term_id ] = $item->name; - } - //foreach - } - //if - } else if ( $type == "pages" || $type == "page" ) { - if ( ! isset ( $args['posts_per_page'] ) ) { - $args['posts_per_page'] = 20; - } - $pages = get_pages( $args ); - if ( ! empty ( $pages ) ) { - foreach ( $pages as $page ) { - $data[ $page->ID ] = $page->post_title; - } - //foreach - } - //if - } else if ( $type == "terms" || $type == "term" ) { - $taxonomies = $args['taxonomies']; - unset ( $args['taxonomies'] ); - $terms = get_terms( $taxonomies, $args ); // this will get nothing - if ( ! empty ( $terms ) ) { - foreach ( $terms as $term ) { - $data[ $term->term_id ] = $term->name; - } - //foreach - } // If - } else if ( $type == "taxonomy" || $type == "taxonomies" ) { - $taxonomies = get_taxonomies( $args ); - if ( ! empty ( $taxonomies ) ) { - foreach ( $taxonomies as $key => $taxonomy ) { - $data[ $key ] = $taxonomy; - } - //foreach - } // If - } else if ( $type == "posts" || $type == "post" ) { - $posts = get_posts( $args ); - if ( ! empty ( $posts ) ) { - foreach ( $posts as $post ) { - $data[ $post->ID ] = $post->post_title; - } - //foreach - } - //if - } else if ( $type == "post_type" || $type == "post_types" ) { - global $wp_post_types; - - $defaults = array( - 'public' => true, - 'exclude_from_search' => false, - ); - $args = wp_parse_args( $args, $defaults ); - $output = 'names'; - $operator = 'and'; - $post_types = get_post_types( $args, $output, $operator ); - - ksort( $post_types ); - - foreach ( $post_types as $name => $title ) { - if ( isset ( $wp_post_types[ $name ]->labels->menu_name ) ) { - $data[ $name ] = $wp_post_types[ $name ]->labels->menu_name; - } else { - $data[ $name ] = ucfirst( $name ); - } - } - } else if ( $type == "tags" || $type == "tag" ) { // NOT WORKING! - $tags = get_tags( $args ); - if ( ! empty ( $tags ) ) { - foreach ( $tags as $tag ) { - $data[ $tag->term_id ] = $tag->name; - } - //foreach - } - //if - } else if ( $type == "menu_location" || $type == "menu_locations" ) { - global $_wp_registered_nav_menus; - - foreach ( $_wp_registered_nav_menus as $k => $v ) { - $data[ $k ] = $v; - } - } else if ( $type == "image_size" || $type == "image_sizes" ) { - global $_wp_additional_image_sizes; - - foreach ( $_wp_additional_image_sizes as $size_name => $size_attrs ) { - $data[ $size_name ] = $size_name . ' - ' . $size_attrs['width'] . ' x ' . $size_attrs['height']; - } - } else if ( $type == "elusive-icons" || $type == "elusive-icon" || $type == "elusive" || - $type == "font-icon" || $type == "font-icons" || $type == "icons" - ) { - - /** - * filter 'redux-font-icons' - * - * @deprecated - * - * @param array $font_icons array of elusive icon classes - */ - $font_icons = apply_filters( 'redux-font-icons', array() ); // REMOVE LATER - - /** - * filter 'redux/font-icons' - * - * @deprecated - * - * @param array $font_icons array of elusive icon classes - */ - $font_icons = apply_filters( 'redux/font-icons', $font_icons ); - - /** - * filter 'redux/{opt_name}/field/font/icons' - * - * @deprecated - * - * @param array $font_icons array of elusive icon classes - */ - $font_icons = apply_filters( "redux/{$this->args['opt_name']}/field/font/icons", $font_icons ); - - foreach ( $font_icons as $k ) { - $data[ $k ] = $k; - } - } else if ( $type == "roles" ) { - /** @global WP_Roles $wp_roles */ - global $wp_roles; - - $data = $wp_roles->get_names(); - } else if ( $type == "sidebars" || $type == "sidebar" ) { - /** @global array $wp_registered_sidebars */ - global $wp_registered_sidebars; - - foreach ( $wp_registered_sidebars as $key => $value ) { - $data[ $key ] = $value['name']; - } - } else if ( $type == "capabilities" ) { - /** @global WP_Roles $wp_roles */ - global $wp_roles; - - foreach ( $wp_roles->roles as $role ) { - foreach ( $role['capabilities'] as $key => $cap ) { - $data[ $key ] = ucwords( str_replace( '_', ' ', $key ) ); - } - } - } else if ( $type == "callback" ) { - if ( ! is_array( $args ) ) { - $args = array( $args ); - } - $data = call_user_func( $args[0] ); - } - //if - } - //if - - $this->wp_data[ $type . $argsKey ] = $data; - } - - //if - - return $data; - } -// get_wordpress_data() - - /** - * ->show(); This is used to echo and option value from the options array - * - * @since 1.0.0 - * @access public - * - * @param string $opt_name The name of the option being shown - * @param mixed $default The value to show if $opt_name isn't set - * - * @return void - */ - public function show( $opt_name, $default = '' ) { - $option = $this->get( $opt_name ); - if ( ! is_array( $option ) && $option != '' ) { - echo $option; - } elseif ( $default != '' ) { - echo $this->_get_default( $opt_name, $default ); - } - } -// show() - - /** - * Get the default value for an option - * - * @since 3.3.6 - * @access public - * - * @param string $key The option's ID - * @param string $array_key The key of the default's array - * - * @return mixed - */ - public function get_default_value( $key, $array_key = false ) { - if ( empty ( $this->options_defaults ) ) { - $this->options_defaults = $this->_default_values(); - } - - $defaults = $this->options_defaults; - $value = ''; - - if ( isset ( $defaults[ $key ] ) ) { - if ( $array_key !== false && isset ( $defaults[ $key ][ $array_key ] ) ) { - $value = $defaults[ $key ][ $array_key ]; - } else { - $value = $defaults[ $key ]; - } - } - - return $value; - } - - public function field_default_values( $field ) { - // Detect what field types are being used - if ( ! isset ( $this->fields[ $field['type'] ][ $field['id'] ] ) ) { - $this->fields[ $field['type'] ][ $field['id'] ] = 1; - } else { - $this->fields[ $field['type'] ] = array( $field['id'] => 1 ); - } - if ( isset ( $field['default'] ) ) { - $this->options_defaults[ $field['id'] ] = $field['default']; - } elseif ( ( $field['type'] != "ace_editor" ) ) { - // Sorter data filter - - if ( isset( $field['data'] ) && ! empty( $field['data'] ) ) { - if ( ! isset( $field['args'] ) ) { - $field['args'] = array(); - } - if ( is_array( $field['data'] ) && ! empty( $field['data'] ) ) { - foreach ( $field['data'] as $key => $data ) { - if ( ! empty( $data ) ) { - if ( ! isset ( $this->field['args'][ $key ] ) ) { - $field['args'][ $key ] = array(); - } - $field['options'][ $key ] = $this->get_wordpress_data( $data, $field['args'][ $key ] ); - } - } - } else { - $field['options'] = $this->get_wordpress_data( $field['data'], $field['args'] ); - } - } - - if ( $field['type'] == "sorter" && isset ( $field['data'] ) && ! empty ( $field['data'] ) && is_array( $field['data'] ) ) { - if ( ! isset ( $field['args'] ) ) { - $field['args'] = array(); - } - foreach ( $field['data'] as $key => $data ) { - if ( ! isset ( $field['args'][ $key ] ) ) { - $field['args'][ $key ] = array(); - } - $field['options'][ $key ] = $this->get_wordpress_data( $data, $field['args'][ $key ] ); - } - } - - if ( isset ( $field['options'] ) ) { - if ( $field['type'] == "sortable" ) { - $this->options_defaults[ $field['id'] ] = array(); - } elseif ( $field['type'] == "image_select" ) { - $this->options_defaults[ $field['id'] ] = ''; - } elseif ( $field['type'] == "select" ) { - $this->options_defaults[ $field['id'] ] = ''; - } else { - $this->options_defaults[ $field['id'] ] = $field['options']; - } - } - } - } - - /** - * Get default options into an array suitable for the settings API - * - * @since 1.0.0 - * @access public - * @return array $this->options_defaults - */ - public function _default_values() { - if ( ! is_null( $this->sections ) && is_null( $this->options_defaults ) ) { - - // fill the cache - foreach ( $this->sections as $sk => $section ) { - if ( ! isset ( $section['id'] ) ) { - if ( ! is_numeric( $sk ) || ! isset ( $section['title'] ) ) { - $section['id'] = $sk; - } else { - $section['id'] = sanitize_title( $section['title'], $sk ); - } - $this->sections[ $sk ] = $section; - } - if ( isset ( $section['fields'] ) ) { - foreach ( $section['fields'] as $k => $field ) { - if ( empty ( $field['id'] ) && empty ( $field['type'] ) ) { - continue; - } - - if ( in_array( $field['type'], array( 'ace_editor' ) ) && isset ( $field['options'] ) ) { - $this->sections[ $sk ]['fields'][ $k ]['args'] = $field['options']; - unset ( $this->sections[ $sk ]['fields'][ $k ]['options'] ); - } - - if ( $field['type'] == "section" && isset ( $field['indent'] ) && $field['indent'] == "true" ) { - $field['class'] = isset ( $field['class'] ) ? $field['class'] : ''; - $field['class'] .= "redux-section-indent-start"; - $this->sections[ $sk ]['fields'][ $k ] = $field; - } - $this->field_default_values( $field ); - } - } - } - } - - /** - * filter 'redux/options/{opt_name}/defaults' - * - * @param array $defaults option default values - */ - $this->transients['changed_values'] = isset ( $this->transients['changed_values'] ) ? $this->transients['changed_values'] : array(); - $this->options_defaults = apply_filters( "redux/options/{$this->args['opt_name']}/defaults", $this->options_defaults, $this->transients['changed_values'] ); - - return $this->options_defaults; - } - - /** - * Set default options on admin_init if option doesn't exist - * - * @since 1.0.0 - * @access public - * @return void - */ - private function _default_cleanup() { - - // Fix the global variable name - if ( $this->args['global_variable'] == "" && $this->args['global_variable'] !== false ) { - $this->args['global_variable'] = str_replace( '-', '_', $this->args['opt_name'] ); - } - - // Force dev_mode on WP_DEBUG = true and if it's a local server - if ( Redux_Helpers::isLocalHost() || ( Redux_Helpers::isWpDebug() ) ) { - if ( $this->args['dev_mode'] != true ) { - $this->args['update_notice'] = false; - } - $this->dev_mode_forced = true; - $this->args['dev_mode'] = true; - if ( isset( $this->args['forced_dev_mode_off'] ) && $this->args['forced_dev_mode_off'] == true ) { - $this->dev_mode_forced = false; - $this->args['dev_mode'] = false; - } - } - - // Auto create the page_slug appropriately - if ( empty( $this->args['page_slug'] ) ) { - if ( ! empty( $this->args['display_name'] ) ) { - $this->args['page_slug'] = sanitize_html_class( $this->args['display_name'] ); - } else if ( ! empty( $this->args['page_title'] ) ) { - $this->args['page_slug'] = sanitize_html_class( $this->args['page_title'] ); - } else if ( ! empty( $this->args['menu_title'] ) ) { - $this->args['page_slug'] = sanitize_html_class( $this->args['menu_title'] ); - } else { - $this->args['page_slug'] = str_replace( '-', '_', $this->args['opt_name'] ); - } - } - - if ( isset( $this->args['customizer_only'] ) && $this->args['customizer_only'] == true ) { - $this->args['menu_type'] = 'hidden'; - $this->args['customizer'] = true; - $this->args['admin_bar'] = false; - $this->args['allow_sub_menu'] = false; - } - - // Check if the Airplane Mode plugin is installed - if ( class_exists( 'Airplane_Mode_Core' ) ) { - $airplane = Airplane_Mode_Core::getInstance(); - if ( method_exists( $airplane, 'enabled' ) ) { - if ( $airplane->enabled() ) { - $this->args['use_cdn'] = false; - } - } else if ( $airplane->check_status() == 'on' ) { - $this->args['use_cdn'] = false; - } - } - } - - /** - * Class Add Sub Menu Function, creates options submenu in Wordpress admin area. - * - * @since 3.1.9 - * @access private - * @return void - */ - private function add_submenu( $page_parent, $page_title, $menu_title, $page_permissions, $page_slug ) { - global $submenu; - - // Just in case. One never knows. - $page_parent = strtolower( $page_parent ); - - $test = array( - 'index.php' => 'dashboard', - 'edit.php' => 'posts', - 'upload.php' => 'media', - 'link-manager.php' => 'links', - 'edit.php?post_type=page' => 'pages', - 'edit-comments.php' => 'comments', - 'themes.php' => 'theme', - 'plugins.php' => 'plugins', - 'users.php' => 'users', - 'tools.php' => 'management', - 'options-general.php' => 'options', - ); - - if ( isset ( $test[ $page_parent ] ) ) { - $function = 'add_' . $test[ $page_parent ] . '_page'; - $this->page = $function ( - $page_title, $menu_title, $page_permissions, $page_slug, array( $this, 'generate_panel' ) - ); - } else { - // Network settings and Post type menus. These do not have - // wrappers and need to be appened to using add_submenu_page. - // Okay, since we've left the post type menu appending - // as default, we need to validate it, so anything that - // isn't post_type= doesn't get through and mess - // things up. - $addMenu = false; - if ( 'settings.php' != $page_parent ) { - // Establish the needle - $needle = '?post_type='; - - // Check if it exists in the page_parent (how I miss instr) - $needlePos = strrpos( $page_parent, $needle ); - - // It's there, so... - if ( $needlePos > 0 ) { - - // Get the post type. - $postType = substr( $page_parent, $needlePos + strlen( $needle ) ); - - // Ensure it exists. - if ( post_type_exists( $postType ) ) { - // Set flag to add the menu page - $addMenu = true; - } - // custom menu - } elseif ( isset ( $submenu[ $this->args['page_parent'] ] ) ) { - $addMenu = true; - } else { - global $menu; - - foreach ( $menu as $menupriority => $menuitem ) { - $needle_menu_slug = isset ( $menuitem ) ? $menuitem[2] : false; - if ( $needle_menu_slug != false ) { - - // check if the current needle menu equals page_parent - if ( strcasecmp( $needle_menu_slug, $page_parent ) == 0 ) { - - // found an empty parent menu - $addMenu = true; - } - } - } - } - } else { - // The page_parent was settings.php, so set menu add - // flag to true. - $addMenu = true; - } - // Add the submenu if it's permitted. - if ( true == $addMenu ) { - // ONLY for non-wp.org themes OR plugins. Theme-Check alert shown if used and IS theme. - $this->page = call_user_func( 'add_submenu_page', $page_parent, $page_title, $menu_title, $page_permissions, $page_slug, array( - &$this, - 'generate_panel' - ) ); - } - } - } - - /** - * Class Options Page Function, creates main options page. - * - * @since 1.0.0 - * @access public - * @return void - */ - public function _options_page() { - - if ( $this->args['menu_type'] == 'hidden' ) { - - // No menu to add! - } else if ( $this->args['menu_type'] == 'submenu' ) { - $this->add_submenu( - $this->args['page_parent'], $this->args['page_title'], $this->args['menu_title'], $this->args['page_permissions'], $this->args['page_slug'] - ); - } else { - // Theme-Check notice is displayed for WP.org theme devs, informing them to NOT use this. - $this->page = call_user_func( 'add_menu_page', $this->args['page_title'], $this->args['menu_title'], $this->args['page_permissions'], $this->args['page_slug'], array( - &$this, - 'generate_panel' - ), $this->args['menu_icon'], $this->args['page_priority'] - ); - - if ( true === $this->args['allow_sub_menu'] ) { - if ( ! isset ( $section['type'] ) || $section['type'] != 'divide' ) { - foreach ( $this->sections as $k => $section ) { - $canBeSubSection = ( $k > 0 && ( ! isset ( $this->sections[ ( $k ) ]['type'] ) || $this->sections[ ( $k ) ]['type'] != "divide" ) ) ? true : false; - - if ( ! isset ( $section['title'] ) || ( $canBeSubSection && ( isset ( $section['subsection'] ) && $section['subsection'] == true ) ) ) { - continue; - } - - if ( isset ( $section['submenu'] ) && $section['submenu'] == false ) { - continue; - } - - if ( isset ( $section['customizer_only'] ) && $section['customizer_only'] == true ) { - continue; - } - - if ( isset ( $section['hidden'] ) && $section['hidden'] == true ) { - continue; - } - - if ( isset( $section['permissions'] ) && ! current_user_can( $section['permissions'] ) ) { - continue; - } - - // ONLY for non-wp.org themes OR plugins. Theme-Check alert shown if used and IS theme. - call_user_func( 'add_submenu_page', $this->args['page_slug'], $section['title'], $section['title'], $this->args['page_permissions'], $this->args['page_slug'] . '&tab=' . $k, - //create_function( '$a', "return null;" ) - '__return_null' ); - } - - // Remove parent submenu item instead of adding null item. - remove_submenu_page( $this->args['page_slug'], $this->args['page_slug'] ); - } - } - } - - add_action( "load-{$this->page}", array( &$this, '_load_page' ) ); - } -// _options_page() - - /** - * Add admin bar menu - * - * @since 3.1.5.16 - * @access public - * @global $menu , $submenu, $wp_admin_bar - * @return void - */ - public function _admin_bar_menu() { - global $menu, $submenu, $wp_admin_bar; - - $ct = wp_get_theme(); - $theme_data = $ct; - - if ( ! is_super_admin() || ! is_admin_bar_showing() || ! $this->args['admin_bar'] || $this->args['menu_type'] == 'hidden' ) { - return; - } - - if ( $menu ) { - foreach ( $menu as $menu_item ) { - if ( isset ( $menu_item[2] ) && $menu_item[2] === $this->args["page_slug"] ) { - - // Fetch the title - $title = empty ( $this->args['admin_bar_icon'] ) ? $menu_item[0] : '' . $menu_item[0]; - - $nodeargs = array( - 'id' => $menu_item[2], - 'title' => $title, - 'href' => admin_url( 'admin.php?page=' . $menu_item[2] ), - 'meta' => array() - ); - $wp_admin_bar->add_node( $nodeargs ); - - break; - } - } - - if ( isset ( $submenu[ $this->args["page_slug"] ] ) && is_array( $submenu[ $this->args["page_slug"] ] ) ) { - foreach ( $submenu[ $this->args["page_slug"] ] as $index => $redux_options_submenu ) { - $subnodeargs = array( - 'id' => $this->args["page_slug"] . '_' . $index, - 'title' => $redux_options_submenu[0], - 'parent' => $this->args["page_slug"], - 'href' => admin_url( 'admin.php?page=' . $redux_options_submenu[2] ), - ); - - $wp_admin_bar->add_node( $subnodeargs ); - } - } - - // Let's deal with external links - if ( isset ( $this->args['admin_bar_links'] ) ) { - - // Group for Main Root Menu (External Group) - $wp_admin_bar->add_node( array( - 'id' => $this->args["page_slug"] . '-external', - 'parent' => $this->args["page_slug"], - 'group' => true, - 'meta' => array( 'class' => 'ab-sub-secondary' ) - ) ); - - // Add Child Menus to External Group Menu - foreach ( $this->args['admin_bar_links'] as $link ) { - if ( ! isset ( $link['id'] ) ) { - $link['id'] = $this->args["page_slug"] . '-sub-' . sanitize_html_class( $link['title'] ); - } - $externalnodeargs = array( - 'id' => $link['id'], - 'title' => $link['title'], - 'parent' => $this->args["page_slug"] . '-external', - 'href' => $link['href'], - 'meta' => array( 'target' => '_blank' ) - ); - - $wp_admin_bar->add_node( $externalnodeargs ); - } - } - } else { - // Fetch the title - $title = empty ( $this->args['admin_bar_icon'] ) ? $this->args['menu_title'] : '' . $this->args['menu_title']; - - $nodeargs = array( - 'id' => $this->args["page_slug"], - 'title' => $title, - // $theme_data->get( 'Name' ) . " " . __( 'Options', 'redux-framework-demo' ), - 'href' => admin_url( 'admin.php?page=' . $this->args["page_slug"] ), - 'meta' => array() - ); - - $wp_admin_bar->add_node( $nodeargs ); - } - } -// _admin_bar_menu() - - /** - * Output dynamic CSS at bottom of HEAD - * - * @since 3.2.8 - * @access public - * @return void - */ - public function _output_css() { - if ( $this->args['output'] == false && $this->args['compiler'] == false ) { - return; - } - - if ( isset ( $this->no_output ) ) { - return; - } - - if ( ! empty ( $this->outputCSS ) && ( $this->args['output_tag'] == true || ( isset ( $_POST['customized'] ) ) ) ) { - echo ''; - } - } - - /** - * Enqueue CSS and Google fonts for front end - * - * @since 1.0.0 - * @access public - * @return void - */ - public function _enqueue_output() { - if ( $this->args['output'] == false && $this->args['compiler'] == false ) { - return; - } - - /** @noinspection PhpUnusedLocalVariableInspection */ - foreach ( $this->sections as $k => $section ) { - if ( isset ( $section['type'] ) && ( $section['type'] == 'divide' ) ) { - continue; - } - - if ( isset ( $section['fields'] ) ) { - /** @noinspection PhpUnusedLocalVariableInspection */ - foreach ( $section['fields'] as $fieldk => $field ) { - if ( isset ( $field['type'] ) && $field['type'] != "callback" ) { - $field_class = "ReduxFramework_{$field['type']}"; - if ( ! class_exists( $field_class ) ) { - - if ( ! isset ( $field['compiler'] ) ) { - $field['compiler'] = ""; - } - - /** - * Field class file - * filter 'redux/{opt_name}/field/class/{field.type} - * - * @param string field class file - * @param array $field field config data - */ - $class_file = apply_filters( "redux/{$this->args['opt_name']}/field/class/{$field['type']}", self::$_dir . "inc/fields/{$field['type']}/field_{$field['type']}.php", $field ); - - if ( $class_file && file_exists( $class_file ) && ! class_exists( $field_class ) ) { - /** @noinspection PhpIncludeInspection */ - require_once $class_file; - } - } - - if ( ! empty ( $this->options[ $field['id'] ] ) && class_exists( $field_class ) && method_exists( $field_class, 'output' ) && $this->_can_output_css( $field ) ) { - $field = apply_filters( "redux/field/{$this->args['opt_name']}/output_css", $field ); - - if ( ! empty ( $field['output'] ) && ! is_array( $field['output'] ) ) { - $field['output'] = array( $field['output'] ); - } - - $value = isset ( $this->options[ $field['id'] ] ) ? $this->options[ $field['id'] ] : ''; - $enqueue = new $field_class ( $field, $value, $this ); - - if ( ( ( isset ( $field['output'] ) && ! empty ( $field['output'] ) ) || ( isset ( $field['compiler'] ) && ! empty ( $field['compiler'] ) ) || $field['type'] == "typography" || $field['type'] == "icon_select" ) ) { - $enqueue->output(); - } - } - } - } - } - } - - // For use like in the customizer. Stops the output, but passes the CSS in the variable for the compiler - if ( isset ( $this->no_output ) ) { - return; - } - - if ( ! empty ( $this->typography ) && ! empty ( $this->typography ) && filter_var( $this->args['output'], FILTER_VALIDATE_BOOLEAN ) ) { - $version = ! empty ( $this->transients['last_save'] ) ? $this->transients['last_save'] : ''; - $typography = new ReduxFramework_typography ( null, null, $this ); - - if ( $this->args['async_typography'] && ! empty ( $this->typography ) ) { - $families = array(); - foreach ( $this->typography as $key => $value ) { - $families[] = $key; - } - ?> - - args['disable_google_fonts_link'] ) { - $protocol = ( ! empty ( $_SERVER['HTTPS'] ) && $_SERVER['HTTPS'] !== 'off' || $_SERVER['SERVER_PORT'] == 443 ) ? "https:" : "http:"; - - //echo ''; - wp_register_style( 'redux-google-fonts-' . $this->args['opt_name'], $protocol . $typography->makeGoogleWebfontLink( $this->typography ), '', $version ); - wp_enqueue_style( 'redux-google-fonts-' . $this->args['opt_name'] ); - } - } - } -// _enqueue_output() - - /** - * Enqueue CSS/JS for options page - * - * @since 1.0.0 - * @access public - * @global $wp_styles - * @return void - */ - public function _enqueue() { - require_once 'core/enqueue.php'; - $enqueue = new reduxCoreEnqueue ( $this ); - $enqueue->init(); - } -// _enqueue() - - /** - * Show page help - * - * @since 1.0.0 - * @access public - * @return void - */ - public function _load_page() { - - // Do admin head action for this page - add_action( 'admin_head', array( &$this, 'admin_head' ) ); - - // Do admin footer text hook - add_filter( 'admin_footer_text', array( &$this, 'admin_footer_text' ) ); - - $screen = get_current_screen(); - - if ( is_array( $this->args['help_tabs'] ) ) { - foreach ( $this->args['help_tabs'] as $tab ) { - $screen->add_help_tab( $tab ); - } - } - - // If hint argument is set, display hint tab - if ( true == $this->show_hints ) { - global $current_user; - - // Users enable/disable hint choice - $hint_status = get_user_meta( $current_user->ID, 'ignore_hints' ) ? get_user_meta( $current_user->ID, 'ignore_hints', true ) : 'true'; - - // current page parameters - $curPage = $_GET['page']; - - $curTab = '0'; - if ( isset ( $_GET['tab'] ) ) { - $curTab = $_GET['tab']; - } - - // Default url values for enabling hints. - $dismiss = 'true'; - $s = __( 'Enable', 'redux-framework' ); - - // Values for disabling hints. - if ( 'true' == $hint_status ) { - $dismiss = 'false'; - $s = __( 'Disable', 'redux-framework' ); - } - - // Make URL - $url = '' . $s . ' hints'; - - $event = __( 'moving the mouse over', 'redux-framework' ); - if ( 'click' == $this->args['hints']['tip_effect']['show']['event'] ) { - $event = __( 'clicking', 'redux-framework' ); - } - - // Construct message - $msg = sprintf( __( 'Hints are tooltips that popup when %d the hint icon, offering addition information about the field in which they appear. They can be %d d by using the link below.', 'redux-framework' ), $event, strtolower( $s ) ) . '

    ' . $url; - - // Construct hint tab - $tab = array( - 'id' => 'redux-hint-tab', - 'title' => __( 'Hints', 'redux-framework' ), - 'content' => '

    ' . $msg . '

    ' - ); - - $screen->add_help_tab( $tab ); - } - - // Sidebar text - if ( $this->args['help_sidebar'] != '' ) { - - // Specify users text from arguments - $screen->set_help_sidebar( $this->args['help_sidebar'] ); - } else { - - // If sidebar text is empty and hints are active, display text - // about hints. - if ( true == $this->show_hints ) { - $screen->set_help_sidebar( '

    Redux Framework

    Hint Tooltip Preferences

    ' ); - } - } - - /** - * action 'redux-load-page-{opt_name}' - * - * @deprecated - * - * @param object $screen WP_Screen - */ - do_action( "redux-load-page-{$this->args['opt_name']}", $screen ); // REMOVE - - /** - * action 'redux/page/{opt_name}/load' - * - * @param object $screen WP_Screen - */ - do_action( "redux/page/{$this->args['opt_name']}/load", $screen ); - } -// _load_page() - - /** - * Do action redux-admin-head for options page - * - * @since 1.0.0 - * @access public - * @return void - */ - public function admin_head() { - /** - * action 'redux-admin-head-{opt_name}' - * - * @deprecated - * - * @param object $this ReduxFramework - */ - do_action( "redux-admin-head-{$this->args['opt_name']}", $this ); // REMOVE - - /** - * action 'redux/page/{opt_name}/header' - * - * @param object $this ReduxFramework - */ - do_action( "redux/page/{$this->args['opt_name']}/header", $this ); - } -// admin_head() - - /** - * Return footer text - * - * @since 2.0.0 - * @access public - * @return string $this->args['footer_credit'] - */ - public function admin_footer_text() { - return $this->args['footer_credit']; - } -// admin_footer_text() - - /** - * Return default output string for use in panel - * - * @since 3.1.5 - * @access public - * @return string default_output - */ - private function get_default_output_string( $field ) { - $default_output = ""; - - if ( ! isset ( $field['default'] ) ) { - $field['default'] = ""; - } - - if ( ! is_array( $field['default'] ) ) { - if ( ! empty ( $field['options'][ $field['default'] ] ) ) { - if ( ! empty ( $field['options'][ $field['default'] ]['alt'] ) ) { - $default_output .= $field['options'][ $field['default'] ]['alt'] . ', '; - } else { - // TODO: This serialize fix may not be the best solution. Look into it. PHP 5.4 error without serialize - if ( ! is_array( $field['options'][ $field['default'] ] ) ) { - $default_output .= $field['options'][ $field['default'] ] . ", "; - } else { - $default_output .= serialize( $field['options'][ $field['default'] ] ) . ", "; - } - } - } else if ( ! empty ( $field['options'][ $field['default'] ] ) ) { - $default_output .= $field['options'][ $field['default'] ] . ", "; - } else if ( ! empty ( $field['default'] ) ) { - if ( $field['type'] == 'switch' && isset ( $field['on'] ) && isset ( $field['off'] ) ) { - $default_output .= ( $field['default'] == 1 ? $field['on'] : $field['off'] ) . ', '; - } else { - $default_output .= $field['default'] . ', '; - } - } - } else { - foreach ( $field['default'] as $defaultk => $defaultv ) { - if ( ! empty ( $field['options'][ $defaultv ]['alt'] ) ) { - $default_output .= $field['options'][ $defaultv ]['alt'] . ', '; - } else if ( ! empty ( $field['options'][ $defaultv ] ) ) { - $default_output .= $field['options'][ $defaultv ] . ", "; - } else if ( ! empty ( $field['options'][ $defaultk ] ) ) { - $default_output .= $field['options'][ $defaultk ] . ", "; - } else if ( ! empty ( $defaultv ) ) { - $default_output .= $defaultv . ', '; - } - } - } - - if ( ! empty ( $default_output ) ) { - $default_output = __( 'Default', 'redux-framework' ) . ": " . substr( $default_output, 0, - 2 ); - } - - if ( ! empty ( $default_output ) ) { - $default_output = '' . $default_output . '
    '; - } - - return $default_output; - } - -// get_default_output_string() - - public function get_header_html( $field ) { - global $current_user; - - // Set to empty string to avoid wanrings. - $hint = ''; - $th = ""; - - if ( isset ( $field['title'] ) && isset ( $field['type'] ) && $field['type'] !== "info" && $field['type'] !== "section" ) { - $default_mark = ( ! empty ( $field['default'] ) && isset ( $this->options[ $field['id'] ] ) && $this->options[ $field['id'] ] == $field['default'] && ! empty ( $this->args['default_mark'] ) && isset ( $field['default'] ) ) ? $this->args['default_mark'] : ''; - - // If a hint is specified in the field, process it. - if ( isset ( $field['hint'] ) && ! '' == $field['hint'] ) { - - // Set show_hints flag to true, so helptab will be displayed. - $this->show_hints = true; - - // Get user pref for displaying hints. - $metaVal = get_user_meta( $current_user->ID, 'ignore_hints', true ); - if ( 'true' == $metaVal || empty ( $metaVal ) ) { - - // Set hand cursor for clickable hints - $pointer = ''; - if ( isset ( $this->args['hints']['tip_effect']['show']['event'] ) && 'click' == $this->args['hints']['tip_effect']['show']['event'] ) { - $pointer = 'pointer'; - } - - $size = '16px'; - if ( 'large' == $this->args['hints']['icon_size'] ) { - $size = '18px'; - } - - // In case docs are ignored. - $titleParam = isset ( $field['hint']['title'] ) ? $field['hint']['title'] : ''; - $contentParam = isset ( $field['hint']['content'] ) ? $field['hint']['content'] : ''; - - $hint_color = isset ( $this->args['hints']['icon_color'] ) ? $this->args['hints']['icon_color'] : '#d3d3d3'; - - // Set hint html with appropriate position css - $hint = '
     
    '; - } - } - - if ( ! empty ( $field['title'] ) ) { - if ( 'left' == $this->args['hints']['icon_position'] ) { - $th = $hint . $field['title'] . $default_mark . ""; - } else { - $th = $field['title'] . $default_mark . "" . $hint; - } - } - - if ( isset ( $field['subtitle'] ) ) { - $th .= '' . $field['subtitle'] . ''; - } - } - - if ( ! empty ( $th ) ) { - $th = '
    ' . $th . '
    '; - } - - $filter_arr = array( - 'editor', - 'ace_editor', - 'info', - 'section', - 'repeater', - 'color_scheme', - 'social_profiles', - 'css_layout' - ); - - if ( $this->args['default_show'] == true && isset ( $field['default'] ) && isset ( $this->options[ $field['id'] ] ) && $this->options[ $field['id'] ] != $field['default'] && ! in_array( $field['type'], $filter_arr ) ) { - $th .= $this->get_default_output_string( $field ); - } - - return $th; - } - - /** - * Register Option for use - * - * @since 1.0.0 - * @access public - * @return void - */ - public function _register_settings() { - - // TODO - REMOVE - // Not used by new sample-config, but in here for legacy builds - // This is bad and can break things. Hehe. - if ( ! function_exists( 'wp_get_current_user' ) ) { - require_once ABSPATH . "wp-includes/pluggable.php"; - } - - if ( $this->args['options_api'] == true ) { - register_setting( $this->args['opt_name'] . '_group', $this->args['opt_name'], array( - $this, - '_validate_options' - ) ); - } - - - if ( is_null( $this->sections ) ) { - return; - } - - if ( empty( $this->options_defaults ) ) { - $this->options_defaults = $this->_default_values(); - } - - $runUpdate = false; - - foreach ( $this->sections as $k => $section ) { - if ( isset ( $section['type'] ) && $section['type'] == 'divide' ) { - continue; - } - - $display = true; - - if ( isset ( $_GET['page'] ) && $_GET['page'] == $this->args['page_slug'] ) { - if ( isset ( $section['panel'] ) && $section['panel'] == false ) { - $display = false; - } - } - - - // DOVY! Replace $k with $section['id'] when ready - /** - * filter 'redux-section-{index}-modifier-{opt_name}' - * - * @param array $section section configuration - */ - $section = apply_filters( "redux-section-{$k}-modifier-{$this->args['opt_name']}", $section ); - - /** - * filter 'redux/options/{opt_name}/section/{section.id}' - * - * @param array $section section configuration - */ - if ( isset ( $section['id'] ) ) { - $section = apply_filters( "redux/options/{$this->args['opt_name']}/section/{$section['id']}", $section ); - } - - if ( empty ( $section ) ) { - unset ( $this->sections[ $k ] ); - continue; - } - - if ( ! isset ( $section['title'] ) ) { - $section['title'] = ""; - } - - $heading = isset ( $section['heading'] ) ? $section['heading'] : $section['title']; - - if ( isset ( $section['permissions'] ) ) { - if ( ! current_user_can( $section['permissions'] ) ) { - $this->hidden_perm_sections[] = $section['title']; - - foreach ( $section['fields'] as $num => $field_data ) { - $field_type = $field_data['type']; - - if ( $field_type != 'section' || $field_type != 'divide' || $field_type != 'info' || $field_type != 'raw' ) { - $field_id = $field_data['id']; - $default = isset ( $this->options_defaults[ $field_id ] ) ? $this->options_defaults[ $field_id ] : ''; - $data = isset ( $this->options[ $field_id ] ) ? $this->options[ $field_id ] : $default; - - $this->hidden_perm_fields[ $field_id ] = $data; - } - } - - continue; - } - } - - if ( ! $display || ! function_exists( 'add_settings_section' ) ) { - $this->no_panel_section[ $k ] = $section; - } else { - add_settings_section( $this->args['opt_name'] . $k . '_section', $heading, array( - &$this, - '_section_desc' - ), $this->args['opt_name'] . $k . '_section_group' ); - } - - $sectionIndent = false; - if ( isset ( $section['fields'] ) ) { - foreach ( $section['fields'] as $fieldk => $field ) { - if ( ! isset ( $field['type'] ) ) { - continue; // You need a type! - } - - if ( $field['type'] == "info" && isset( $field['raw_html'] ) && $field['raw_html'] == true ) { - $field['type'] = "raw"; - $field['content'] = $field['desc']; - $field['desc'] = ""; - $this->sections[ $k ]['fields'][ $fieldk ] = $field; - } else if ( $field['type'] == "info" ) { - if ( ! isset( $field['full_width'] ) ) { - $field['full_width'] = true; - $this->sections[ $k ]['fields'][ $fieldk ] = $field; - } - } - - if ( $field['type'] == "raw" ) { - if ( isset( $field['align'] ) ) { - $field['full_width'] = $field['align'] ? false : true; - unset( $field['align'] ); - } else if ( ! isset( $field['full_width'] ) ) { - $field['full_width'] = true; - } - $this->sections[ $k ]['fields'][ $fieldk ] = $field; - } - - - /** - * filter 'redux/options/{opt_name}/field/{field.id}' - * - * @param array $field field config - */ - $field = apply_filters( "redux/options/{$this->args['opt_name']}/field/{$field['id']}/register", $field ); - - - $this->field_types[ $field['type'] ] = isset ( $this->field_types[ $field['type'] ] ) ? $this->field_types[ $field['type'] ] : array(); - - $this->field_sections[ $field['type'] ][ $field['id'] ] = $k; - - $display = true; - - if ( isset ( $_GET['page'] ) && $_GET['page'] == $this->args['page_slug'] ) { - if ( isset ( $field['panel'] ) && $field['panel'] == false ) { - $display = false; - } - } - if ( isset ( $field['customizer_only'] ) && $field['customizer_only'] == true ) { - $display = false; - } - - - if ( isset ( $field['permissions'] ) ) { - - if ( ! current_user_can( $field['permissions'] ) ) { - $data = isset ( $this->options[ $field['id'] ] ) ? $this->options[ $field['id'] ] : $this->options_defaults[ $field['id'] ]; - - $this->hidden_perm_fields[ $field['id'] ] = $data; - - continue; - } - } - - if ( ! isset ( $field['id'] ) ) { - echo '

    No field ID is set.

    ';
    -                                print_r( $field );
    -                                echo "

    "; - continue; - } - - if ( isset ( $field['type'] ) && $field['type'] == "section" ) { - if ( isset ( $field['indent'] ) && $field['indent'] == true ) { - $sectionIndent = true; - } else { - $sectionIndent = false; - } - } - - if ( isset ( $field['type'] ) && $field['type'] == "info" && $sectionIndent ) { - $field['indent'] = $sectionIndent; - } - - $th = $this->get_header_html( $field ); - - $field['name'] = $this->args['opt_name'] . '[' . $field['id'] . ']'; - - // Set the default value if present - $this->options_defaults[ $field['id'] ] = isset ( $this->options_defaults[ $field['id'] ] ) ? $this->options_defaults[ $field['id'] ] : ''; - - // Set the defaults to the value if not present - $doUpdate = false; - - // Check fields for values in the default parameter - if ( ! isset ( $this->options[ $field['id'] ] ) && isset ( $field['default'] ) ) { - $this->options_defaults[ $field['id'] ] = $this->options[ $field['id'] ] = $field['default']; - $doUpdate = true; - - // Check fields that hae no default value, but an options value with settings to - // be saved by default - } elseif ( ! isset ( $this->options[ $field['id'] ] ) && isset ( $field['options'] ) ) { - - // If sorter field, check for options as save them as defaults - if ( $field['type'] == 'sorter' || $field['type'] == 'sortable' ) { - $this->options_defaults[ $field['id'] ] = $this->options[ $field['id'] ] = $field['options']; - $doUpdate = true; - } - } - - // CORRECT URLS if media URLs are wrong, but attachment IDs are present. - if ( $field['type'] == "media" ) { - if ( isset ( $this->options[ $field['id'] ]['id'] ) && isset ( $this->options[ $field['id'] ]['url'] ) && ! empty ( $this->options[ $field['id'] ]['url'] ) && strpos( $this->options[ $field['id'] ]['url'], str_replace( 'http://', '', WP_CONTENT_URL ) ) === false ) { - $data = wp_get_attachment_url( $this->options[ $field['id'] ]['id'] ); - - if ( isset ( $data ) && ! empty ( $data ) ) { - $this->options[ $field['id'] ]['url'] = $data; - $data = wp_get_attachment_image_src( $this->options[ $field['id'] ]['id'], array( - 150, - 150 - ) ); - $this->options[ $field['id'] ]['thumbnail'] = $data[0]; - $doUpdate = true; - } - } - } - - if ( $field['type'] == "background" ) { - if ( isset ( $this->options[ $field['id'] ]['media']['id'] ) && isset ( $this->options[ $field['id'] ]['background-image'] ) && ! empty ( $this->options[ $field['id'] ]['background-image'] ) && strpos( $this->options[ $field['id'] ]['background-image'], str_replace( 'http://', '', WP_CONTENT_URL ) ) === false ) { - $data = wp_get_attachment_url( $this->options[ $field['id'] ]['media']['id'] ); - - if ( isset ( $data ) && ! empty ( $data ) ) { - $this->options[ $field['id'] ]['background-image'] = $data; - $data = wp_get_attachment_image_src( $this->options[ $field['id'] ]['media']['id'], array( - 150, - 150 - ) ); - $this->options[ $field['id'] ]['media']['thumbnail'] = $data[0]; - $doUpdate = true; - } - } - } - - if ( $field['type'] == "slides" ) { - if ( isset ( $this->options[ $field['id'] ] ) && is_array( $this->options[ $field['id'] ] ) && isset ( $this->options[ $field['id'] ][0]['attachment_id'] ) && isset ( $this->options[ $field['id'] ][0]['image'] ) && ! empty ( $this->options[ $field['id'] ][0]['image'] ) && strpos( $this->options[ $field['id'] ][0]['image'], str_replace( 'http://', '', WP_CONTENT_URL ) ) === false ) { - foreach ( $this->options[ $field['id'] ] as $key => $val ) { - $data = wp_get_attachment_url( $val['attachment_id'] ); - - if ( isset ( $data ) && ! empty ( $data ) ) { - $this->options[ $field['id'] ][ $key ]['image'] = $data; - $data = wp_get_attachment_image_src( $val['attachment_id'], array( - 150, - 150 - ) ); - $this->options[ $field['id'] ][ $key ]['thumb'] = $data[0]; - $doUpdate = true; - } - } - } - } - // END -> CORRECT URLS if media URLs are wrong, but attachment IDs are present. - - if ( true == $doUpdate && ! isset ( $this->never_save_to_db ) ) { - if ( $this->args['save_defaults'] ) { // Only save that to the DB if allowed to - $runUpdate = true; - } - // elseif($this->saved != '' && $this->saved != false) { - // $runUpdate = true; - //} - } - - if ( ! isset ( $field['class'] ) ) { // No errors please - $field['class'] = ""; - } - $id = $field['id']; - - /** - * filter 'redux-field-{field.id}modifier-{opt_name}' - * - * @deprecated - * - * @param array $field field config - */ - $field = apply_filters( "redux-field-{$field['id']}modifier-{$this->args['opt_name']}", $field ); // REMOVE LATER - - /** - * filter 'redux/options/{opt_name}/field/{field.id}' - * - * @param array $field field config - */ - $field = apply_filters( "redux/options/{$this->args['opt_name']}/field/{$field['id']}", $field ); - - if ( empty ( $field ) || ! $field || $field == false ) { - unset ( $this->sections[ $k ]['fields'][ $fieldk ] ); - continue; - } - - if ( ! empty ( $this->folds[ $field['id'] ]['parent'] ) ) { // This has some fold items, hide it by default - $field['class'] .= " fold"; - } - - if ( ! empty ( $this->folds[ $field['id'] ]['children'] ) ) { // Sets the values you shoe fold children on - $field['class'] .= " foldParent"; - } - - if ( ! empty ( $field['compiler'] ) ) { - $field['class'] .= " compiler"; - $this->compiler_fields[ $field['id'] ] = 1; - } - - if ( isset ( $field['unit'] ) && ! isset ( $field['units'] ) ) { - $field['units'] = $field['unit']; - unset ( $field['unit'] ); - } - - $this->sections[ $k ]['fields'][ $fieldk ] = $field; - - if ( isset ( $this->args['display_source'] ) ) { - $th .= ''; - $th .= '
    View Source'; - } - - /** - * action 'redux/options/{opt_name}/field/field.type}/register' - */ - do_action( "redux/options/{$this->args['opt_name']}/field/{$field['type']}/register", $field ); - - $this->check_dependencies( $field ); - $this->field_head[ $field['id'] ] = $th; - - if ( ! $display || isset ( $this->no_panel_section[ $k ] ) ) { - $this->no_panel[] = $field['id']; - } else { - if ( isset ( $field['hidden'] ) && $field['hidden'] ) { - $field['label_for'] = 'redux_hide_field'; - } - if ( $this->args['options_api'] == true ) { - add_settings_field( - "{$fieldk}_field", $th, array( - &$this, - '_field_input' - ), "{$this->args['opt_name']}{$k}_section_group", "{$this->args['opt_name']}{$k}_section", $field - ); - } - } - } - } - } - - /** - * action 'redux-register-settings-{opt_name}' - * - * @deprecated - */ - do_action( "redux-register-settings-{$this->args['opt_name']}" ); // REMOVE - - /** - * action 'redux/options/{opt_name}/register' - * - * @param array option sections - */ - do_action( "redux/options/{$this->args['opt_name']}/register", $this->sections ); - - if ( $runUpdate && ! isset ( $this->never_save_to_db ) ) { // Always update the DB with new fields - $this->set_options( $this->options ); - } - - if ( isset ( $this->transients['run_compiler'] ) && $this->transients['run_compiler'] ) { - - $this->no_output = true; - $this->_enqueue_output(); - - - /** - * action 'redux-compiler-{opt_name}' - * - * @deprecated - * - * @param array options - * @param string CSS that get sent to the compiler hook - */ - do_action( "redux-compiler-{$this->args['opt_name']}", $this->options, $this->compilerCSS, $this->transients['changed_values'] ); // REMOVE - - /** - * action 'redux/options/{opt_name}a' - * - * @param array options - * @param string CSS that get sent to the compiler hook - */ - do_action( "redux/options/{$this->args['opt_name']}/compiler", $this->options, $this->compilerCSS, $this->transients['changed_values'] ); - - /** - * action 'redux/options/{opt_name}/compiler/advanced' - * - * @param array options - * @param string CSS that get sent to the compiler hook, which sends the full Redux object - */ - do_action( "redux/options/{$this->args['opt_name']}/compiler/advanced", $this ); - - unset ( $this->transients['run_compiler'] ); - $this->set_transients(); - } - } -// _register_settings() - - /** - * Register Extensions for use - * - * @since 3.0.0 - * @access public - * @return void - */ - private function _register_extensions() { - $path = dirname( __FILE__ ) . '/inc/extensions/'; - $folders = scandir( $path, 1 ); - - /** - * action 'redux/extensions/before' - * - * @param object $this ReduxFramework - */ - do_action( "redux/extensions/before", $this ); - - /** - * action 'redux/extensions/{opt_name}/before' - * - * @param object $this ReduxFramework - */ - do_action( "redux/extensions/{$this->args['opt_name']}/before", $this ); - - if ( isset( $this->old_opt_name ) ) { - do_action( "redux/extensions/{$this->old_opt_name}/before", $this ); - } - - foreach ( $folders as $folder ) { - if ( $folder === '.' || $folder === '..' || ! is_dir( $path . $folder ) || substr( $folder, 0, 1 ) === '.' || substr( $folder, 0, 1 ) === '@' || substr( $folder, 0, 4 ) === '_vti' ) { - continue; - } - - $extension_class = 'ReduxFramework_Extension_' . $folder; - - /** - * filter 'redux-extensionclass-load' - * - * @deprecated - * - * @param string extension class file path - * @param string $extension_class extension class name - */ - $class_file = apply_filters( "redux-extensionclass-load", "$path/$folder/extension_{$folder}.php", $extension_class ); // REMOVE LATER - - /** - * filter 'redux/extension/{opt_name}/{folder}' - * - * @param string extension class file path - * @param string $extension_class extension class name - */ - $class_file = apply_filters( "redux/extension/{$this->args['opt_name']}/$folder", "$path/$folder/extension_{$folder}.php", $class_file ); - - if ( $class_file ) { - if ( file_exists( $class_file ) ) { - require_once $class_file; - } - - $this->extensions[ $folder ] = new $extension_class ( $this ); - } - } - - /** - * action 'redux-register-extensions-{opt_name}' - * - * @deprecated - * - * @param object $this ReduxFramework - */ - do_action( "redux-register-extensions-{$this->args['opt_name']}", $this ); // REMOVE - - /** - * action 'redux/extensions/{opt_name}' - * - * @param object $this ReduxFramework - */ - do_action( "redux/extensions/{$this->args['opt_name']}", $this ); - - if ( isset( $this->old_opt_name ) && ! empty( $this->old_opt_name ) ) { - do_action( "redux/extensions/{$this->old_opt_name}", $this ); - } - } - - private function get_transients() { - if ( ! isset ( $this->transients ) ) { - $this->transients = get_option( $this->args['opt_name'] . '-transients', array() ); - $this->transients_check = $this->transients; - } - } - - public function set_transients() { - if ( ! isset ( $this->transients ) || ! isset ( $this->transients_check ) || $this->transients != $this->transients_check ) { - update_option( $this->args['opt_name'] . '-transients', $this->transients ); - $this->transients_check = $this->transients; - } - } - - /** - * Validate the Options options before insertion - * - * @since 3.0.0 - * @access public - * - * @param array $plugin_options The options array - * - * @return array|mixed|string|void - */ - public function _validate_options( $plugin_options ) { -//print_r($plugin_options); - // exit(); - if ( isset ( $this->validation_ran ) ) { - return $plugin_options; - } - $this->validation_ran = 1; - - // Save the values not in the panel - if ( isset ( $plugin_options['redux-no_panel'] ) ) { - $keys = explode( '|', $plugin_options['redux-no_panel'] ); - foreach ( $keys as $key ) { - $plugin_options[ $key ] = $this->options[ $key ]; - } - if ( isset ( $plugin_options['redux-no_panel'] ) ) { - unset ( $plugin_options['redux-no_panel'] ); - } - } - - if ( ! empty ( $this->hidden_perm_fields ) && is_array( $this->hidden_perm_fields ) ) { - foreach ( $this->hidden_perm_fields as $id => $data ) { - $plugin_options[ $id ] = $data; - } - } - - if ( $plugin_options == $this->options ) { - return $plugin_options; - } - - $time = time(); - - // Sets last saved time - $this->transients['last_save'] = $time; - - // Import - if ( ( isset( $plugin_options['import_code'] ) && ! empty( $plugin_options['import_code'] ) ) || ( isset( $plugin_options['import_link'] ) && ! empty( $plugin_options['import_link'] ) ) ) { - $this->transients['last_save_mode'] = "import"; // Last save mode - $this->transients['last_compiler'] = $time; - $this->transients['last_import'] = $time; - $this->transients['run_compiler'] = 1; - - if ( $plugin_options['import_code'] != '' ) { - $import = $plugin_options['import_code']; - } elseif ( $plugin_options['import_link'] != '' ) { - $import = wp_remote_retrieve_body( wp_remote_get( $plugin_options['import_link'] ) ); - } - - if ( ! empty ( $import ) ) { - $imported_options = json_decode( $import, true ); - } - - if ( ! empty ( $imported_options ) && is_array( $imported_options ) && isset ( $imported_options['redux-backup'] ) && $imported_options['redux-backup'] == '1' ) { - - $this->transients['changed_values'] = array(); - foreach ( $plugin_options as $key => $value ) { - if ( isset ( $imported_options[ $key ] ) && $imported_options[ $key ] != $value ) { - $this->transients['changed_values'][ $key ] = $value; - $plugin_options[ $key ] = $value; - } - } - - /** - * action 'redux/options/{opt_name}/import' - * - * @param &array [&$plugin_options, redux_options] - */ - do_action_ref_array( "redux/options/{$this->args['opt_name']}/import", array( - &$plugin_options, - $imported_options, - $this->transients['changed_values'] - ) ); - - setcookie( 'redux_current_tab', '', 1, '/', $time + 1000, "/" ); - $_COOKIE['redux_current_tab'] = 1; - - unset ( $plugin_options['defaults'], $plugin_options['compiler'], $plugin_options['import'], $plugin_options['import_code'] ); - if ( $this->args['database'] == 'transient' || $this->args['database'] == 'theme_mods' || $this->args['database'] == 'theme_mods_expanded' || $this->args['database'] == 'network' ) { - $this->set_options( $plugin_options ); - - return; - } - - $plugin_options = wp_parse_args( $imported_options, $plugin_options ); - - $this->set_transients(); // Update the transients - - return $plugin_options; - } - } - - // Reset all to defaults - if ( ! empty ( $plugin_options['defaults'] ) ) { - if ( empty ( $this->options_defaults ) ) { - $this->options_defaults = $this->_default_values(); - } - - /** - * apply_filters 'redux/validate/{opt_name}/defaults' - * - * @param &array [ $this->options_defaults, $plugin_options] - */ - $plugin_options = apply_filters( "redux/validate/{$this->args['opt_name']}/defaults", $this->options_defaults ); - - // Section reset - //setcookie('redux-compiler-' . $this->args['opt_name'], 1, time() + 3000, '/'); - - - $this->transients['changed_values'] = array(); - - if ( empty ( $this->options ) ) { - $this->options = $this->options_defaults; - } - - foreach ( $this->options as $key => $value ) { - if ( isset ( $plugin_options[ $key ] ) && $value != $plugin_options[ $key ] ) { - $this->transients['changed_values'][ $key ] = $value; - } - } - - $this->transients['run_compiler'] = 1; - $this->transients['last_save_mode'] = "defaults"; // Last save mode - //setcookie('redux-compiler-' . $this->args['opt_name'], 1, time() + 1000, "/"); - //setcookie("redux-saved-{$this->args['opt_name']}", 'defaults', time() + 1000, "/"); - - $this->set_transients(); // Update the transients - - return $plugin_options; - } - - // Section reset to defaults - if ( ! empty ( $plugin_options['defaults-section'] ) ) { - if ( isset ( $plugin_options['redux-section'] ) && isset ( $this->sections[ $plugin_options['redux-section'] ]['fields'] ) ) { - /** - * apply_filters 'redux/validate/{opt_name}/defaults_section' - * - * @param &array [ $this->options_defaults, $plugin_options] - */ - foreach ( $this->sections[ $plugin_options['redux-section'] ]['fields'] as $field ) { - if ( isset ( $this->options_defaults[ $field['id'] ] ) ) { - $plugin_options[ $field['id'] ] = $this->options_defaults[ $field['id'] ]; - } else { - $plugin_options[ $field['id'] ] = ""; - } - - if ( isset ( $field['compiler'] ) ) { - $compiler = true; - } - } - - $plugin_options = apply_filters( "redux/validate/{$this->args['opt_name']}/defaults_section", $plugin_options ); - } - - $this->transients['changed_values'] = array(); - foreach ( $this->options as $key => $value ) { - if ( isset ( $plugin_options[ $key ] ) && $value != $plugin_options[ $key ] ) { - $this->transients['changed_values'][ $key ] = $value; - } - } - - if ( isset ( $compiler ) ) { - //$this->run_compiler = true; - //setcookie('redux-compiler-' . $this->args['opt_name'], 1, time()+1000, '/'); - //$plugin_options['REDUX_COMPILER'] = time(); - $this->transients['last_compiler'] = $time; - $this->transients['run_compiler'] = 1; - } - - $this->transients['last_save_mode'] = "defaults_section"; // Last save mode - //setcookie("redux-saved-{$this->args['opt_name']}", 'defaults_section', time() + 1000, "/"); - unset ( $plugin_options['defaults'], $plugin_options['defaults_section'], $plugin_options['import'], $plugin_options['import_code'], $plugin_options['import_link'], $plugin_options['compiler'], $plugin_options['redux-section'] ); - - $this->set_transients(); - - return $plugin_options; - } - -// if ($this->transients['last_save_mode'] != 'remove') { - $this->transients['last_save_mode'] = "normal"; // Last save mode -// } else { -// $this->transients['last_save_mode'] = ''; -// } - - /** - * apply_filters 'redux/validate/{opt_name}/before_validation' - * - * @param &array [&$plugin_options, redux_options] - */ - $plugin_options = apply_filters( "redux/validate/{$this->args['opt_name']}/before_validation", $plugin_options, $this->options ); - - // Validate fields (if needed) - $plugin_options = $this->_validate_values( $plugin_options, $this->options, $this->sections ); - - if ( ! empty ( $this->errors ) || ! empty ( $this->warnings ) ) { - $this->transients['notices'] = array( 'errors' => $this->errors, 'warnings' => $this->warnings ); - } - - /** - * action 'redux-validate-{opt_name}' - * - * @deprecated - * - * @param &array [&$plugin_options, redux_options] - */ - do_action_ref_array( "redux-validate-{$this->args['opt_name']}", array( - &$plugin_options, - $this->options - ) ); // REMOVE - - if ( ! isset ( $this->transients['changed_values'] ) ) { - $this->transients['changed_values'] = array(); - } - - /** - * action 'redux/options/{opt_name}/validate' - * - * @param &array [&$plugin_options, redux_options] - */ - do_action_ref_array( "redux/options/{$this->args['opt_name']}/validate", array( - &$plugin_options, - $this->options, - $this->transients['changed_values'] - ) ); - - if ( ! empty ( $plugin_options['compiler'] ) ) { - unset ( $plugin_options['compiler'] ); - - $this->transients['last_compiler'] = $time; - $this->transients['run_compiler'] = 1; - } - - $this->transients['changed_values'] = array(); // Changed values since last save - foreach ( $this->options as $key => $value ) { - if ( isset ( $plugin_options[ $key ] ) && $value != $plugin_options[ $key ] ) { - $this->transients['changed_values'][ $key ] = $value; - } - } - - unset ( $plugin_options['defaults'], $plugin_options['defaults_section'], $plugin_options['import'], $plugin_options['import_code'], $plugin_options['import_link'], $plugin_options['compiler'], $plugin_options['redux-section'] ); - if ( $this->args['database'] == 'transient' || $this->args['database'] == 'theme_mods' || $this->args['database'] == 'theme_mods_expanded' ) { - $this->set_options( $plugin_options ); - - return; - } - - if ( defined( 'WP_CACHE' ) && WP_CACHE && class_exists( 'W3_ObjectCache' ) && function_exists( 'w3_instance' ) ) { - //echo "here"; - $w3_inst = w3_instance( 'W3_ObjectCache' ); - $w3 = $w3_inst->instance(); - $key = $w3->_get_cache_key( $this->args['opt_name'] . '-transients', 'transient' ); - //echo $key; - $w3->delete( $key, 'transient', true ); - //set_transient($this->args['opt_name'].'-transients', $this->transients); - //exit(); - } - - $this->set_transients( $this->transients ); - - return $plugin_options; - } - - public function ajax_save() { - - - if ( ! wp_verify_nonce( $_REQUEST['nonce'], "redux_ajax_nonce" ) ) { - json_encode( array( - 'status' => __( 'Invalid security credential, please reload the page and try again.', 'redux-framework' ), - 'action' => 'reload' - ) ); - die(); - } - $redux = ReduxFrameworkInstances::get_instance( $_POST['opt_name'] ); - - if ( ! empty ( $_POST['data'] ) && ! empty ( $redux->args['opt_name'] ) ) { - - $values = array(); - //if (function_exists('get_magic_quotes_gpc') && get_magic_quotes_gpc()) { - // $process = array(&$_GET, &$_POST, &$_COOKIE, &$_REQUEST); - // while (list($key, $val) = each($process)) { - // foreach ($val as $k => $v) { - // unset($process[$key][$k]); - // if (is_array($v)) { - // $process[$key][stripslashes($k)] = $v; - // $process[] = &$process[$key][stripslashes($k)]; - // } else { - // $process[$key][stripslashes($k)] = stripslashes($v); - // } - // } - // } - // unset($process); - //} - $_POST['data'] = stripslashes( $_POST['data'] ); - parse_str( $_POST['data'], $values ); - $values = $values[ $redux->args['opt_name'] ]; - - - if ( function_exists( 'get_magic_quotes_gpc' ) && get_magic_quotes_gpc() ) { - $values = array_map( 'stripslashes_deep', $values ); - } - - //$beforeDeep = $values; - //// Ace editor hack for < PHP 5.4. Oy - //if ( isset( $this->fields['ace_editor'] ) ) { - // if ( function_exists( 'get_magic_quotes_gpc' ) && get_magic_quotes_gpc() ) { - // foreach ( $this->fields['ace_editor'] as $id => $v ) { - // if ( version_compare( phpversion(), '5.4', '<' ) ) { - // $values[ $id ] = stripslashes( $beforeDeep[ $id ] ); - // } else { - // $values[ $id ] = $beforeDeep[ $id ]; - // } - // } - // } - //} - - if ( ! empty ( $values ) ) { - - try { - if ( isset ( $redux->validation_ran ) ) { - unset ( $redux->validation_ran ); - } - $redux->set_options( $redux->_validate_options( $values ) ); - - $do_reload = false; - if (isset($this->reload_fields) && !empty($this->reload_fields)) { - if (!empty($this->transients['changed_values'])) { - foreach ($this->reload_fields as $idx => $val) { - if ( array_key_exists ( $val, $this->transients['changed_values'] )) { - $do_reload = true; - } - } - } - } - - if ( $do_reload || ( isset ( $values['defaults'] ) && ! empty ( $values['defaults'] ) ) || ( isset ( $values['defaults-section'] ) && ! empty ( $values['defaults-section'] ) )) { - echo json_encode( array( 'status' => 'success', 'action' => 'reload' ) ); - die (); - } - - require_once 'core/enqueue.php'; - $enqueue = new reduxCoreEnqueue ( $redux ); - $enqueue->get_warnings_and_errors_array(); - - $return_array = array( - 'status' => 'success', - 'options' => $redux->options, - 'errors' => isset ( $redux->localize_data['errors'] ) ? $redux->localize_data['errors'] : null, - 'warnings' => isset ( $redux->localize_data['warnings'] ) ? $redux->localize_data['warnings'] : null, - ); - - } catch ( Exception $e ) { - $return_array = array( 'status' => $e->getMessage() ); - } - } else { - echo json_encode( array( 'status' => __( 'Your panel has no fields. Nothing to save.', 'redux-framework' ) ) ); - } - } - if ( isset ( $this->transients['run_compiler'] ) && $this->transients['run_compiler'] ) { - - $this->no_output = true; - $this->_enqueue_output(); - - try { - /** - * action 'redux-compiler-{opt_name}' - * - * @deprecated - * - * @param array options - * @param string CSS that get sent to the compiler hook - */ - do_action( "redux-compiler-{$this->args['opt_name']}", $this->options, $this->compilerCSS, $this->transients['changed_values'] ); // REMOVE - - /** - * action 'redux/options/{opt_name}/compiler' - * - * @param array options - * @param string CSS that get sent to the compiler hook - */ - do_action( "redux/options/{$this->args['opt_name']}/compiler", $this->options, $this->compilerCSS, $this->transients['changed_values'] ); - - /** - * action 'redux/options/{opt_name}/compiler/advanced' - * - * @param array options - * @param string CSS that get sent to the compiler hook, which sends the full Redux object - */ - do_action( "redux/options/{$this->args['opt_name']}/compiler/advanced", $this ); - } catch ( Exception $e ) { - $return_array = array( 'status' => $e->getMessage() ); - } - - unset ( $this->transients['run_compiler'] ); - $this->set_transients(); - } - if ( isset( $return_array ) ) { - if ( $return_array['status'] == "success" ) { - require_once 'core/panel.php'; - $panel = new reduxCorePanel ( $redux ); - ob_start(); - $panel->notification_bar(); - $notification_bar = ob_get_contents(); - ob_end_clean(); - $return_array['notification_bar'] = $notification_bar; - } - - echo json_encode( apply_filters( "redux/options/{$this->args['opt_name']}/ajax_save/response", $return_array ) ); - } - - die (); - - } - - /** - * Validate values from options form (used in settings api validate function) - * calls the custom validation class for the field so authors can override with custom classes - * - * @since 1.0.0 - * @access public - * - * @param array $plugin_options - * @param array $options - * - * @return array $plugin_options - */ - public function _validate_values( $plugin_options, $options, $sections ) { - foreach ( $sections as $k => $section ) { - if ( isset ( $section['fields'] ) ) { - foreach ( $section['fields'] as $fkey => $field ) { - - if ( is_array( $field ) ) { - $field['section_id'] = $k; - } - - if ( isset ( $field['type'] ) && ( $field['type'] == 'checkbox' || $field['type'] == 'checkbox_hide_below' || $field['type'] == 'checkbox_hide_all' ) ) { - if ( ! isset ( $plugin_options[ $field['id'] ] ) ) { - $plugin_options[ $field['id'] ] = 0; - } - } - - // Default 'not_empty 'flag to false. - $isNotEmpty = false; - - // Make sure 'validate' field is set. - if ( isset ( $field['validate'] ) ) { - - // Make sure 'validate field' is set to 'not_empty' or 'email_not_empty' - //if ( $field['validate'] == 'not_empty' || $field['validate'] == 'email_not_empty' || $field['validate'] == 'numeric_not_empty' ) { - if ( strtolower( substr( $field['validate'], - 9 ) ) == 'not_empty' ) { - - // Set the flag. - $isNotEmpty = true; - } - } - - // Check for empty id value - - if ( ! isset ( $field['id'] ) || ! isset ( $plugin_options[ $field['id'] ] ) || ( isset ( $plugin_options[ $field['id'] ] ) && $plugin_options[ $field['id'] ] == '' ) ) { - - // If we are looking for an empty value, in the case of 'not_empty' - // then we need to keep processing. - if ( ! $isNotEmpty ) { - - // Empty id and not checking for 'not_empty. Bail out... - continue; - } - } - - // Force validate of custom field types - if ( isset ( $field['type'] ) && ! isset ( $field['validate'] ) && ! isset( $field['validate_callback'] ) ) { - if ( $field['type'] == 'color' || $field['type'] == 'color_gradient' ) { - $field['validate'] = 'color'; - } elseif ( $field['type'] == 'date' ) { - $field['validate'] = 'date'; - } - } - - if ( isset ( $field['validate'] ) ) { - $validate = 'Redux_Validation_' . $field['validate']; - - if ( ! class_exists( $validate ) ) { - /** - * filter 'redux-validateclass-load' - * - * @deprecated - * - * @param string validation class file path - * @param string $validate validation class name - */ - $class_file = apply_filters( "redux-validateclass-load", self::$_dir . "inc/validation/{$field['validate']}/validation_{$field['validate']}.php", $validate ); // REMOVE LATER - - /** - * filter 'redux/validate/{opt_name}/class/{field.validate}' - * - * @param string validation class file path - * @param string $class_file validation class file path - */ - $class_file = apply_filters( "redux/validate/{$this->args['opt_name']}/class/{$field['validate']}", self::$_dir . "inc/validation/{$field['validate']}/validation_{$field['validate']}.php", $class_file ); - - if ( $class_file ) { - if ( file_exists( $class_file ) ) { - require_once $class_file; - } - } - } - - if ( class_exists( $validate ) ) { - - //!DOVY - DB saving stuff. Is this right? - if ( empty ( $options[ $field['id'] ] ) ) { - $options[ $field['id'] ] = ''; - } - - if ( isset ( $plugin_options[ $field['id'] ] ) && is_array( $plugin_options[ $field['id'] ] ) && ! empty ( $plugin_options[ $field['id'] ] ) ) { - foreach ( $plugin_options[ $field['id'] ] as $key => $value ) { - $before = $after = null; - if ( isset ( $plugin_options[ $field['id'] ][ $key ] ) && ( ! empty ( $plugin_options[ $field['id'] ][ $key ] ) || $plugin_options[ $field['id'] ][ $key ] == '0' ) ) { - if ( is_array( $plugin_options[ $field['id'] ][ $key ] ) ) { - $before = $plugin_options[ $field['id'] ][ $key ]; - } else { - $before = trim( $plugin_options[ $field['id'] ][ $key ] ); - } - } - - if ( isset ( $options[ $field['id'] ][ $key ] ) && ( ! empty ( $plugin_options[ $field['id'] ][ $key ] ) || $plugin_options[ $field['id'] ][ $key ] == '0' ) ) { - $after = $options[ $field['id'] ][ $key ]; - } - - $validation = new $validate ( $this, $field, $before, $after ); - if ( ! empty ( $validation->value ) || $validation->value == '0' ) { - $plugin_options[ $field['id'] ][ $key ] = $validation->value; - } else { - unset ( $plugin_options[ $field['id'] ][ $key ] ); - } - - if ( isset ( $validation->error ) ) { - $this->errors[] = $validation->error; - } - - if ( isset ( $validation->warning ) ) { - $this->warnings[] = $validation->warning; - } - } - } else { - if ( is_array( $plugin_options[ $field['id'] ] ) ) { - $pofi = $plugin_options[ $field['id'] ]; - } else { - $pofi = trim( $plugin_options[ $field['id'] ] ); - } - - $validation = new $validate ( $this, $field, $pofi, $options[ $field['id'] ] ); - $plugin_options[ $field['id'] ] = $validation->value; - - if ( isset ( $validation->error ) ) { - $this->errors[] = $validation->error; - } - - if ( isset ( $validation->warning ) ) { - $this->warnings[] = $validation->warning; - } - } - - continue; - } - } - if ( isset ( $field['validate_callback'] ) && ( is_callable( $field['validate_callback'] ) || ( is_string( $field['validate_callback'] ) && function_exists( $field['validate_callback'] ) ) ) ) { - $callback = $field['validate_callback']; - unset ( $field['validate_callback'] ); - - $callbackvalues = call_user_func( $callback, $field, $plugin_options[ $field['id'] ], $options[ $field['id'] ] ); - $plugin_options[ $field['id'] ] = $callbackvalues['value']; - - if ( isset ( $callbackvalues['error'] ) ) { - $this->errors[] = $callbackvalues['error']; - } - // TODO - This warning message is failing. Hmm. - if ( isset ( $callbackvalues['warning'] ) ) { - $this->warnings[] = $callbackvalues['warning']; - } - } - } - } - } - - return $plugin_options; - } - - /** - * Return Section Menu HTML - * - * @since 3.1.5 - * @access public - * @return void - */ - public function section_menu( $k, $section, $suffix = "", $sections = array() ) { - $display = true; - - $section['class'] = isset ( $section['class'] ) ? ' ' . $section['class'] : ''; - - if ( isset ( $_GET['page'] ) && $_GET['page'] == $this->args['page_slug'] ) { - if ( isset ( $section['panel'] ) && $section['panel'] == false ) { - $display = false; - } - } - - if ( ! $display ) { - return ""; - } - - if ( empty ( $sections ) ) { - $sections = $this->sections; - } - - $string = ""; - if ( ( ( isset ( $this->args['icon_type'] ) && $this->args['icon_type'] == 'image' ) || ( isset ( $section['icon_type'] ) && $section['icon_type'] == 'image' ) ) || ( isset($section['icon']) && strpos( $section['icon'], '/' ) !== false ) ) { - //if( !empty( $this->args['icon_type'] ) && $this->args['icon_type'] == 'image' ) { - $icon = ( ! isset ( $section['icon'] ) ) ? '' : ' '; - } else { - if ( ! empty ( $section['icon_class'] ) ) { - $icon_class = ' ' . $section['icon_class']; - } elseif ( ! empty ( $this->args['default_icon_class'] ) ) { - $icon_class = ' ' . $this->args['default_icon_class']; - } else { - $icon_class = ''; - } - $icon = ( ! isset ( $section['icon'] ) ) ? ' ' : ' '; - } - if ( strpos( $icon, 'el-icon-' ) !== false ) { - $icon = str_replace( 'el-icon-', 'el el-', $icon ); - } - - $hide_section = ''; - if ( isset ( $section['hidden'] ) ) { - $hide_section = ( $section['hidden'] == true ) ? ' hidden ' : ''; - } - - $canBeSubSection = ( $k > 0 && ( ! isset ( $sections[ ( $k ) ]['type'] ) || $sections[ ( $k ) ]['type'] != "divide" ) ) ? true : false; - - if ( ! $canBeSubSection && isset ( $section['subsection'] ) && $section['subsection'] == true ) { - unset ( $section['subsection'] ); - } - - if ( isset ( $section['type'] ) && $section['type'] == "divide" ) { - $string .= '
  •  
  • '; - } else if ( ! isset ( $section['subsection'] ) || $section['subsection'] != true ) { - - // DOVY! REPLACE $k with $section['ID'] when used properly. - //$active = ( ( is_numeric($this->current_tab) && $this->current_tab == $k ) || ( !is_numeric($this->current_tab) && $this->current_tab === $k ) ) ? ' active' : ''; - $subsections = ( isset ( $sections[ ( $k + 1 ) ] ) && isset ( $sections[ ( $k + 1 ) ]['subsection'] ) && $sections[ ( $k + 1 ) ]['subsection'] == true ) ? true : false; - $subsectionsClass = $subsections ? ' hasSubSections' : ''; - $subsectionsClass .= ( ! isset ( $section['fields'] ) || empty ( $section['fields'] ) ) ? ' empty_section' : ''; - $extra_icon = $subsections ? ' ' : ''; - $string .= ''; - } - - return $string; - } -// section_menu() - - /** - * HTML OUTPUT. - * - * @since 1.0.0 - * @access public - * @return void - */ - public function generate_panel() { - require_once 'core/panel.php'; - $panel = new reduxCorePanel ( $this ); - $panel->init(); - $this->set_transients(); - } - - /** - * Section HTML OUTPUT. - * - * @since 1.0.0 - * @access public - * - * @param array $section - * - * @return void - */ - public function _section_desc( $section ) { - $id = trim( rtrim( $section['id'], '_section' ), $this->args['opt_name'] ); - - if ( isset ( $this->sections[ $id ]['desc'] ) && ! empty ( $this->sections[ $id ]['desc'] ) ) { - echo '
    ' . $this->sections[ $id ]['desc'] . '
    '; - } - } - - /** - * Field HTML OUTPUT. - * Gets option from options array, then calls the specific field type class - allows extending by other devs - * - * @since 1.0.0 - * - * @param array $field - * @param string $v - * - * @return void - */ - public function _field_input( $field, $v = null ) { - - if ( isset ( $field['callback'] ) && ( is_callable( $field['callback'] ) || ( is_string( $field['callback'] ) && function_exists( $field['callback'] ) ) ) ) { - - $value = ( isset ( $this->options[ $field['id'] ] ) ) ? $this->options[ $field['id'] ] : ''; - - /** - * action 'redux-before-field-{opt_name}' - * - * @deprecated - * - * @param array $field field data - * @param string $value field.id - */ - do_action( "redux-before-field-{$this->args['opt_name']}", $field, $value ); // REMOVE - - /** - * action 'redux/field/{opt_name}/{field.type}/callback/before' - * - * @param array $field field data - * @param string $value field.id - */ - do_action_ref_array( "redux/field/{$this->args['opt_name']}/{$field['type']}/callback/before", array( - &$field, - &$value - ) ); - - /** - * action 'redux/field/{opt_name}/callback/before' - * - * @param array $field field data - * @param string $value field.id - */ - do_action_ref_array( "redux/field/{$this->args['opt_name']}/callback/before", array( - &$field, - &$value - ) ); - - call_user_func( $field['callback'], $field, $value ); - - - /** - * action 'redux-after-field-{opt_name}' - * - * @deprecated - * - * @param array $field field data - * @param string $value field.id - */ - do_action( "redux-after-field-{$this->args['opt_name']}", $field, $value ); // REMOVE - - /** - * action 'redux/field/{opt_name}/{field.type}/callback/after' - * - * @param array $field field data - * @param string $value field.id - */ - do_action_ref_array( "redux/field/{$this->args['opt_name']}/{$field['type']}/callback/after", array( - &$field, - &$value - ) ); - - /** - * action 'redux/field/{opt_name}/callback/after' - * - * @param array $field field data - * @param string $value field.id - */ - do_action_ref_array( "redux/field/{$this->args['opt_name']}/callback/after", array( - &$field, - &$value - ) ); - - - return; - } - - if ( isset ( $field['type'] ) ) { - - // If the field is set not to display in the panel - $display = true; - if ( isset ( $_GET['page'] ) && $_GET['page'] == $this->args['page_slug'] ) { - if ( isset ( $field['panel'] ) && $field['panel'] == false ) { - $display = false; - } - } - - if ( ! $display ) { - return; - } - - $field_class = "ReduxFramework_{$field['type']}"; - - if ( ! class_exists( $field_class ) ) { -// $class_file = apply_filters( 'redux/field/class/'.$field['type'], self::$_dir . 'inc/fields/' . $field['type'] . '/field_' . $field['type'] . '.php', $field ); // REMOVE - /** - * filter 'redux/{opt_name}/field/class/{field.type}' - * - * @param string field class file path - * @param array $field field data - */ - $class_file = apply_filters( "redux/{$this->args['opt_name']}/field/class/{$field['type']}", self::$_dir . "inc/fields/{$field['type']}/field_{$field['type']}.php", $field ); - - if ( $class_file ) { - if ( file_exists( $class_file ) ) { - require_once $class_file; - } - } - } - - if ( class_exists( $field_class ) ) { - $value = isset ( $this->options[ $field['id'] ] ) ? $this->options[ $field['id'] ] : ''; - - if ( $v !== null ) { - $value = $v; - } - - /** - * action 'redux-before-field-{opt_name}' - * - * @deprecated - * - * @param array $field field data - * @param string $value field id - */ - do_action( "redux-before-field-{$this->args['opt_name']}", $field, $value ); // REMOVE - - /** - * action 'redux/field/{opt_name}/{field.type}/render/before' - * - * @param array $field field data - * @param string $value field id - */ - do_action_ref_array( "redux/field/{$this->args['opt_name']}/{$field['type']}/render/before", array( - &$field, - &$value - ) ); - - /** - * action 'redux/field/{$this->args['opt_name']}/render/before' - * - * @param array $field field data - * @param string $value field id - */ - do_action_ref_array( "redux/field/{$this->args['opt_name']}/render/before", array( - &$field, - &$value - ) ); - - if ( ! isset ( $field['name_suffix'] ) ) { - $field['name_suffix'] = ""; - } - - $render = new $field_class ( $field, $value, $this ); - ob_start(); - - $render->render(); - - /* - - echo "
    ";
    -                      print_r($value);
    -                      echo "
    "; - */ - - /** - * filter 'redux-field-{opt_name}' - * - * @deprecated - * - * @param string rendered field markup - * @param array $field field data - */ - $_render = apply_filters( "redux-field-{$this->args['opt_name']}", ob_get_contents(), $field ); // REMOVE - - /** - * filter 'redux/field/{opt_name}/{field.type}/render/after' - * - * @param string rendered field markup - * @param array $field field data - */ - $_render = apply_filters( "redux/field/{$this->args['opt_name']}/{$field['type']}/render/after", $_render, $field ); - - /** - * filter 'redux/field/{opt_name}/render/after' - * - * @param string rendered field markup - * @param array $field field data - */ - $_render = apply_filters( "redux/field/{$this->args['opt_name']}/render/after", $_render, $field ); - - ob_end_clean(); - - //save the values into a unique array in case we need it for dependencies - $this->fieldsValues[ $field['id'] ] = ( isset ( $value['url'] ) && is_array( $value ) ) ? $value['url'] : $value; - - //create default data und class string and checks the dependencies of an object - $class_string = ''; - $data_string = ''; - - $this->check_dependencies( $field ); - - /** - * action 'redux/field/{opt_name}/{field.type}/fieldset/before/{opt_name}' - * - * @param array $field field data - * @param string $value field id - */ - do_action_ref_array( "redux/field/{$this->args['opt_name']}/{$field['type']}/fieldset/before/{$this->args['opt_name']}", array( - &$field, - &$value - ) ); - - /** - * action 'redux/field/{opt_name}/fieldset/before/{opt_name}' - * - * @param array $field field data - * @param string $value field id - */ - do_action_ref_array( "redux/field/{$this->args['opt_name']}/fieldset/before/{$this->args['opt_name']}", array( - &$field, - &$value - ) ); - - //if ( ! isset( $field['fields'] ) || empty( $field['fields'] ) ) { - $hidden = ''; - if ( isset ( $field['hidden'] ) && $field['hidden'] ) { - $hidden = 'hidden '; - } - - if ( isset( $field['full_width'] ) && $field['full_width'] == true ) { - $class_string .= "redux_remove_th"; - } - - if ( isset ( $field['fieldset_class'] ) && ! empty( $field['fieldset_class'] ) ) { - $class_string .= ' ' . $field['fieldset_class']; - } - - echo '
    '; - //} - - echo $_render; - - if ( ! empty ( $field['desc'] ) ) { - $field['description'] = $field['desc']; - } - - echo ( isset ( $field['description'] ) && $field['type'] != "info" && $field['type'] !== "section" && ! empty ( $field['description'] ) ) ? '
    ' . $field['description'] . '
    ' : ''; - - //if ( ! isset( $field['fields'] ) || empty( $field['fields'] ) ) { - echo '
    '; - //} - - /** - * action 'redux-after-field-{opt_name}' - * - * @deprecated - * - * @param array $field field data - * @param string $value field id - */ - do_action( "redux-after-field-{$this->args['opt_name']}", $field, $value ); // REMOVE - - /** - * action 'redux/field/{opt_name}/{field.type}/fieldset/after/{opt_name}' - * - * @param array $field field data - * @param string $value field id - */ - do_action_ref_array( "redux/field/{$this->args['opt_name']}/{$field['type']}/fieldset/after/{$this->args['opt_name']}", array( - &$field, - &$value - ) ); - - /** - * action 'redux/field/{opt_name}/fieldset/after/{opt_name}' - * - * @param array $field field data - * @param string $value field id - */ - do_action_ref_array( "redux/field/{$this->args['opt_name']}/fieldset/after/{$this->args['opt_name']}", array( - &$field, - &$value - ) ); - } - } - } -// _field_input() - - /** - * Can Output CSS - * Check if a field meets its requirements before outputting to CSS - * - * @param $field - * - * @return bool - */ - public function _can_output_css( $field ) { - $return = true; - - $field = apply_filters( "redux/field/{$this->args['opt_name']}/_can_output_css", $field ); - if ( isset ( $field['force_output'] ) && $field['force_output'] == true ) { - return $return; - } - - if ( ! empty ( $field['required'] ) ) { - if ( isset ( $field['required'][0] ) ) { - if ( ! is_array( $field['required'][0] ) && count( $field['required'] ) == 3 ) { - $parentValue = $GLOBALS[ $this->args['global_variable'] ][ $field['required'][0] ]; - $checkValue = $field['required'][2]; - $operation = $field['required'][1]; - $return = $this->compareValueDependencies( $parentValue, $checkValue, $operation ); - } else if ( is_array( $field['required'][0] ) ) { - foreach ( $field['required'] as $required ) { - if ( ! is_array( $required[0] ) && count( $required ) == 3 ) { - $parentValue = $GLOBALS[ $this->args['global_variable'] ][ $required[0] ]; - $checkValue = $required[2]; - $operation = $required[1]; - $return = $this->compareValueDependencies( $parentValue, $checkValue, $operation ); - } - if ( ! $return ) { - return $return; - } - } - } - } - } - - return $return; - } -// _can_output_css - - /** - * Checks dependencies between objects based on the $field['required'] array - * If the array is set it needs to have exactly 3 entries. - * The first entry describes which field should be monitored by the current field. eg: "content" - * The second entry describes the comparison parameter. eg: "equals, not, is_larger, is_smaller ,contains" - * The third entry describes the value that we are comparing against. - * Example: if the required array is set to array('content','equals','Hello World'); then the current - * field will only be displayed if the field with id "content" has exactly the value "Hello World" - * - * @param array $field - * - * @return array $params - */ - public function check_dependencies( $field ) { - //$params = array('data_string' => "", 'class_string' => ""); - if ( isset( $field['ajax_save'] ) && $field['ajax_save'] == false ) { - $this->reload_fields[] = $field['id']; - } - - if ( ! empty ( $field['required'] ) ) { - if ( ! isset ( $this->required_child[ $field['id'] ] ) ) { - $this->required_child[ $field['id'] ] = array(); - } - - if ( ! isset ( $this->required[ $field['id'] ] ) ) { - $this->required[ $field['id'] ] = array(); - } - - if ( is_array( $field['required'][0] ) ) { - - foreach ( $field['required'] as $value ) { - if ( is_array( $value ) && count( $value ) == 3 ) { - $data = array(); - $data['parent'] = $value[0]; - $data['operation'] = $value[1]; - $data['checkValue'] = $value[2]; - - $this->required[ $data['parent'] ][ $field['id'] ][] = $data; - - if ( ! in_array( $data['parent'], $this->required_child[ $field['id'] ] ) ) { - $this->required_child[ $field['id'] ][] = $data; - } - - $this->checkRequiredDependencies( $field, $data ); - } - } - } else { - $data = array(); - $data['parent'] = $field['required'][0]; - $data['operation'] = $field['required'][1]; - $data['checkValue'] = $field['required'][2]; - - $this->required[ $data['parent'] ][ $field['id'] ][] = $data; - - if ( ! in_array( $data['parent'], $this->required_child[ $field['id'] ] ) ) { - $this->required_child[ $field['id'] ][] = $data; - } - - $this->checkRequiredDependencies( $field, $data ); - } - } - //return $params; - } - - // Compare data for required field - private function compareValueDependencies( $parentValue, $checkValue, $operation ) { - $return = false; - switch ( $operation ) { - case '=': - case 'equals': - $data['operation'] = "="; - - if ( is_array( $parentValue ) ) { - foreach ( $parentValue as $idx => $val ) { - if ( is_array( $checkValue ) ) { - foreach ( $checkValue as $i => $v ) { - if ( $val == $v ) { - $return = true; - } - } - } else { - if ( $val == $checkValue ) { - echo $val . '
    '; - echo $checkValue; - $return = true; - } - } - } - } else { - if ( is_array( $checkValue ) ) { - foreach ( $checkValue as $i => $v ) { - if ( $parentValue == $v ) { - $return = true; - } - } - } else { - if ( $parentValue == $checkValue ) { - $return = true; - } - } - } - break; - - case '!=': - case 'not': - $data['operation'] = "!=="; - if ( is_array( $parentValue ) ) { - foreach ( $parentValue as $idx => $val ) { - if ( is_array( $checkValue ) ) { - foreach ( $checkValue as $i => $v ) { - if ( $val != $v ) { - $return = true; - } - } - } else { - if ( $val != $checkValue ) { - $return = true; - } - } - } - } else { - if ( is_array( $checkValue ) ) { - foreach ( $checkValue as $i => $v ) { - if ( $parentValue != $v ) { - $return = true; - } - } - } else { - if ( $parentValue != $checkValue ) { - $return = true; - } - } - } - -// if ( is_array( $checkValue ) ) { -// if ( ! in_array( $parentValue, $checkValue ) ) { -// $return = true; -// } -// } else { -// if ( $parentValue != $checkValue ) { -// $return = true; -// } else if ( is_array( $parentValue ) ) { -// if ( ! in_array( $checkValue, $parentValue ) ) { -// $return = true; -// } -// } -// } - break; - case '>': - case 'greater': - case 'is_larger': - $data['operation'] = ">"; - if ( $parentValue > $checkValue ) { - $return = true; - } - break; - case '>=': - case 'greater_equal': - case 'is_larger_equal': - $data['operation'] = ">="; - if ( $parentValue >= $checkValue ) { - $return = true; - } - break; - case '<': - case 'less': - case 'is_smaller': - $data['operation'] = "<"; - if ( $parentValue < $checkValue ) { - $return = true; - } - break; - case '<=': - case 'less_equal': - case 'is_smaller_equal': - $data['operation'] = "<="; - if ( $parentValue <= $checkValue ) { - $return = true; - } - break; - case 'contains': - if ( is_array( $parentValue ) ) { - $parentValue = implode( ',', $parentValue ); - } - - if ( is_array( $checkValue ) ) { - foreach ( $checkValue as $idx => $opt ) { - if ( strpos( $parentValue, (string) $opt ) !== false ) { - $return = true; - } - } - } else { - if ( strpos( $parentValue, (string) $checkValue ) !== false ) { - $return = true; - } - } - - break; - case 'doesnt_contain': - case 'not_contain': - if ( is_array( $parentValue ) ) { - $parentValue = implode( ',', $parentValue ); - } - - if ( is_array( $checkValue ) ) { - foreach ( $checkValue as $idx => $opt ) { - if ( strpos( $parentValue, (string) $opt ) === false ) { - $return = true; - } - } - } else { - if ( strpos( $parentValue, (string) $checkValue ) === false ) { - $return = true; - } - } - - break; - case 'is_empty_or': - if ( empty ( $parentValue ) || $parentValue == $checkValue ) { - $return = true; - } - break; - case 'not_empty_and': - if ( ! empty ( $parentValue ) && $parentValue != $checkValue ) { - $return = true; - } - break; - case 'is_empty': - case 'empty': - case '!isset': - if ( empty ( $parentValue ) || $parentValue == "" || $parentValue == null ) { - $return = true; - } - break; - case 'not_empty': - case '!empty': - case 'isset': - if ( ! empty ( $parentValue ) && $parentValue != "" && $parentValue != null ) { - $return = true; - } - break; - } - - return $return; - } - - private function checkRequiredDependencies( $field, $data ) { - //required field must not be hidden. otherwise hide this one by default - - if ( ! in_array( $data['parent'], $this->fieldsHidden ) && ( ! isset ( $this->folds[ $field['id'] ] ) || $this->folds[ $field['id'] ] != "hide" ) ) { - if ( isset ( $this->options[ $data['parent'] ] ) ) { - $return = $this->compareValueDependencies( $this->options[ $data['parent'] ], $data['checkValue'], $data['operation'] ); - //$return = $this->compareValueDependencies( $data['parent'], $data['checkValue'], $data['operation'] ); - } - } - - if ( ( isset ( $return ) && $return ) && ( ! isset ( $this->folds[ $field['id'] ] ) || $this->folds[ $field['id'] ] != "hide" ) ) { - $this->folds[ $field['id'] ] = "show"; - } else { - $this->folds[ $field['id'] ] = "hide"; - if ( ! in_array( $field['id'], $this->fieldsHidden ) ) { - $this->fieldsHidden[] = $field['id']; - } - } - } - - /** - * converts an array into a html data string - * - * @param array $data example input: array('id'=>'true') - * - * @return string $data_string example output: data-id='true' - */ - public function create_data_string( $data = array() ) { - $data_string = ""; - - foreach ( $data as $key => $value ) { - if ( is_array( $value ) ) { - $value = implode( "|", $value ); - } - $data_string .= " data-$key='$value' "; - } - - return $data_string; - } - } - - // ReduxFramework - - /** - * action 'redux/init' - * - * @param null - */ - do_action( 'redux/init', ReduxFramework::init() ); - } // class_exists('ReduxFramework') diff --git a/library/admin/ReduxCore/inc/browser.php b/library/admin/ReduxCore/inc/browser.php deleted file mode 100644 index ebf4f812..00000000 --- a/library/admin/ReduxCore/inc/browser.php +++ /dev/null @@ -1,1194 +0,0 @@ -getBrowser() == Browser::BROWSER_FIREFOX && $browser->getVersion() >= 2 ) { - * echo 'You have Firefox version 2 or greater'; - * } - * User agents sampled from: http://www.useragentstring.com/ - * Based on original work from Gary White (http://apptools.com/phptools/browser/ - * CHANGELOG: - * 2012-12-26 (v1.9c by Chris Christoff): - * + Changed vars to publics - * 2012-12-23 (v1.9b by Chris Christoff): - * + Removed the browser string return and added spacing. - * + Also removed return HTML formatting. - * 2012-12-23 (v1.9a by Chris Christoff): - * + Split user string and add formatting so we can print a nicely - * formatted user agent string - * 2010-08-20 (v1.9): - * + Added MSN Explorer Browser (legacy) - * + Added Bing/MSN Robot (Thanks Rob MacDonald) - * + Added the Android Platform (PLATFORM_ANDROID) - * + Fixed issue with Android 1.6/2.2 (Thanks Tom Hirashima) - * 2010-04-27 (v1.8): - * + Added iPad Support - * 2010-03-07 (v1.7): - * + *MAJOR* Rebuild (preg_match and other "slow" routine removal(s)) - * + Almost allof Gary's original code has been replaced - * + Large PHPUNIT testing environment created to validate new releases and additions - * + Added FreeBSD Platform - * + Added OpenBSD Platform - * + Added NetBSD Platform - * + Added SunOS Platform - * + Added OpenSolaris Platform - * + Added support of the Iceweazel Browser - * + Added isChromeFrame() call to check if chromeframe is in use - * + Moved the Opera check in front of the Firefox check due to legacy Opera User Agents - * + Added the __toString() method (Thanks Deano) - * 2009-11-15: - * + Updated the checkes for Firefox - * + Added the NOKIA platform - * + Added Checks for the NOKIA brower(s) - * 2009-11-08: - * + PHP 5.3 Support - * + Added support for BlackBerry OS and BlackBerry browser - * + Added support for the Opera Mini browser - * + Added additional documenation - * + Added support for isRobot() and isMobile() - * + Added support for Opera version 10 - * + Added support for deprecated Netscape Navigator version 9 - * + Added support for IceCat - * + Added support for Shiretoko - * 2010-04-27 (v1.8): - * + Added iPad Support - * 2009-08-18: - * + Updated to support PHP 5.3 - removed all deprecated function calls - * + Updated to remove all double quotes (") -- converted to single quotes (') - * 2009-04-27: - * + Updated the IE check to remove a typo and bug (thanks John) - * 2009-04-22: - * + Added detection for GoogleBot - * + Added detection for the W3C Validator. - * + Added detection for Yahoo! Slurp - * 2009-03-14: - * + Added detection for iPods. - * + Added Platform detection for iPhones - * + Added Platform detection for iPods - * 2009-02-16: (Rick Hale) - * + Added version detection for Android phones. - * 2008-12-09: - * + Removed unused constant - * 2008-11-07: - * + Added Google's Chrome to the detection list - * + Added isBrowser(string) to the list of functions special thanks to - * Daniel 'mavrick' Lang for the function concept (http://mavrick.id.au) - * Gary White noted: "Since browser detection is so unreliable, I am - * no longer maintaining this script. You are free to use and or - * modify/update it as you want, however the author assumes no - * responsibility for the accuracy of the detected values." - * Anyone experienced with Gary's script might be interested in these notes: - * Added class constants - * Added detection and version detection for Google's Chrome - * Updated the version detection for Amaya - * Updated the version detection for Firefox - * Updated the version detection for Lynx - * Updated the version detection for WebTV - * Updated the version detection for NetPositive - * Updated the version detection for IE - * Updated the version detection for OmniWeb - * Updated the version detection for iCab - * Updated the version detection for Safari - * Updated Safari to remove mobile devices (iPhone) - * Added detection for iPhone - * Added detection for robots - * Added detection for mobile devices - * Added detection for BlackBerry - * Removed Netscape checks (matches heavily with firefox & mozilla) - */ - - - // Exit if accessed directly - if ( ! defined( 'ABSPATH' ) ) { - exit; - } - - if ( ! class_exists( 'Browser' ) ) { - - /** - * Browser detection class - * - * @author Chris Schuld - * @since 1.0 - */ - class Browser { - public $_agent = ''; - public $_browser_name = ''; - public $_version = ''; - public $_platform = ''; - public $_os = ''; - public $_is_aol = false; - public $_is_mobile = false; - public $_is_robot = false; - public $_aol_version = ''; - - public $BROWSER_UNKNOWN = 'unknown'; - public $VERSION_UNKNOWN = 'unknown'; - - public $BROWSER_OPERA = 'Opera'; // Http://www.opera.com/ - public $BROWSER_OPERA_MINI = 'Opera Mini'; // Http://www.opera.com/mini/ - public $BROWSER_WEBTV = 'WebTV'; // Http://www.webtv.net/pc/ - public $BROWSER_IE = 'Internet Explorer'; // Http://www.microsoft.com/ie/ - public $BROWSER_POCKET_IE = 'Pocket Internet Explorer'; // Http://en.wikipedia.org/wiki/Internet_Explorer_Mobile - public $BROWSER_KONQUEROR = 'Konqueror'; // Http://www.konqueror.org/ - public $BROWSER_ICAB = 'iCab'; // Http://www.icab.de/ - public $BROWSER_OMNIWEB = 'OmniWeb'; // Http://www.omnigroup.com/applications/omniweb/ - public $BROWSER_FIREBIRD = 'Firebird'; // Http://www.ibphoenix.com/ - public $BROWSER_FIREFOX = 'Firefox'; // Http://www.mozilla.com/en-US/firefox/firefox.html - public $BROWSER_ICEWEASEL = 'Iceweasel'; // Http://www.geticeweasel.org/ - public $BROWSER_SHIRETOKO = 'Shiretoko'; // Http://wiki.mozilla.org/Projects/shiretoko - public $BROWSER_MOZILLA = 'Mozilla'; // Http://www.mozilla.com/en-US/ - public $BROWSER_AMAYA = 'Amaya'; // Http://www.w3.org/Amaya/ - public $BROWSER_LYNX = 'Lynx'; // Http://en.wikipedia.org/wiki/Lynx - public $BROWSER_SAFARI = 'Safari'; // Http://apple.com - public $BROWSER_IPHONE = 'iPhone'; // Http://apple.com - public $BROWSER_IPOD = 'iPod'; // Http://apple.com - public $BROWSER_IPAD = 'iPad'; // Http://apple.com - public $BROWSER_CHROME = 'Chrome'; // Http://www.google.com/chrome - public $BROWSER_ANDROID = 'Android'; // Http://www.android.com/ - public $BROWSER_GOOGLEBOT = 'GoogleBot'; // Http://en.wikipedia.org/wiki/Googlebot - public $BROWSER_SLURP = 'Yahoo! Slurp'; // Http://en.wikipedia.org/wiki/Yahoo!_Slurp - public $BROWSER_W3CVALIDATOR = 'W3C Validator'; // Http://validator.w3.org/ - public $BROWSER_BLACKBERRY = 'BlackBerry'; // Http://www.blackberry.com/ - public $BROWSER_ICECAT = 'IceCat'; // Http://en.wikipedia.org/wiki/GNU_IceCat - public $BROWSER_NOKIA_S60 = 'Nokia S60 OSS Browser'; // Http://en.wikipedia.org/wiki/Web_Browser_for_S60 - public $BROWSER_NOKIA = 'Nokia Browser'; // * all other WAP-based browsers on the Nokia Platform - public $BROWSER_MSN = 'MSN Browser'; // Http://explorer.msn.com/ - public $BROWSER_MSNBOT = 'MSN Bot'; // Http://search.msn.com/msnbot.htm - // Http://en.wikipedia.org/wiki/Msnbot (used for Bing as well) - - public $BROWSER_NETSCAPE_NAVIGATOR = 'Netscape Navigator'; // Http://browser.netscape.com/ (DEPRECATED) - public $BROWSER_GALEON = 'Galeon'; // Http://galeon.sourceforge.net/ (DEPRECATED) - public $BROWSER_NETPOSITIVE = 'NetPositive'; // Http://en.wikipedia.org/wiki/NetPositive (DEPRECATED) - public $BROWSER_PHOENIX = 'Phoenix'; // Http://en.wikipedia.org/wiki/History_of_Mozilla_Firefox (DEPRECATED) - - public $PLATFORM_UNKNOWN = 'unknown'; - public $PLATFORM_WINDOWS = 'Windows'; - public $PLATFORM_WINDOWS_CE = 'Windows CE'; - public $PLATFORM_APPLE = 'Apple'; - public $PLATFORM_LINUX = 'Linux'; - public $PLATFORM_OS2 = 'OS/2'; - public $PLATFORM_BEOS = 'BeOS'; - public $PLATFORM_IPHONE = 'iPhone'; - public $PLATFORM_IPOD = 'iPod'; - public $PLATFORM_IPAD = 'iPad'; - public $PLATFORM_BLACKBERRY = 'BlackBerry'; - public $PLATFORM_NOKIA = 'Nokia'; - public $PLATFORM_FREEBSD = 'FreeBSD'; - public $PLATFORM_OPENBSD = 'OpenBSD'; - public $PLATFORM_NETBSD = 'NetBSD'; - public $PLATFORM_SUNOS = 'SunOS'; - public $PLATFORM_OPENSOLARIS = 'OpenSolaris'; - public $PLATFORM_ANDROID = 'Android'; - - public $OPERATING_SYSTEM_UNKNOWN = 'unknown'; - - function Browser( $useragent = '' ) { - $this->reset(); - - if ( $useragent != '' ) { - $this->setUserAgent( $useragent ); - } else { - $this->determine(); - } - } - - /** - * Reset all properties - */ - function reset() { - $this->_agent = isset( $_SERVER['HTTP_USER_AGENT'] ) ? $_SERVER['HTTP_USER_AGENT'] : ''; - $this->_browser_name = $this->BROWSER_UNKNOWN; - $this->_version = $this->VERSION_UNKNOWN; - $this->_platform = $this->PLATFORM_UNKNOWN; - $this->_os = $this->OPERATING_SYSTEM_UNKNOWN; - $this->_is_aol = false; - $this->_is_mobile = false; - $this->_is_robot = false; - $this->_aol_version = $this->VERSION_UNKNOWN; - } - - /** - * Check to see if the specific browser is valid - * - * @param string $browserName - * - * @return True if the browser is the specified browser - */ - function isBrowser( $browserName ) { - return ( 0 == strcasecmp( $this->_browser_name, trim( $browserName ) ) ); - } - - /** - * The name of the browser. All return types are from the class contants - * - * @return string Name of the browser - */ - function getBrowser() { - return $this->_browser_name; - } - - /** - * Set the name of the browser - * - * @param $browser The name of the Browser - */ - function setBrowser( $browser ) { - return $this->_browser_name = $browser; - } - - /** - * The name of the platform. All return types are from the class contants - * - * @return string Name of the browser - */ - function getPlatform() { - return $this->_platform; - } - - /** - * Set the name of the platform - * - * @param $platform The name of the Platform - */ - function setPlatform( $platform ) { - return $this->_platform = $platform; - } - - /** - * The version of the browser. - * - * @return string Version of the browser (will only contain alpha-numeric characters and a period) - */ - function getVersion() { - return $this->_version; - } - - /** - * Set the version of the browser - * - * @param $version The version of the Browser - */ - function setVersion( $version ) { - $this->_version = preg_replace( '/[^0-9,.,a-z,A-Z-]/', '', $version ); - } - - /** - * The version of AOL. - * - * @return string Version of AOL (will only contain alpha-numeric characters and a period) - */ - function getAolVersion() { - return $this->_aol_version; - } - - /** - * Set the version of AOL - * - * @param $version The version of AOL - */ - function setAolVersion( $version ) { - $this->_aol_version = preg_replace( '/[^0-9,.,a-z,A-Z]/', '', $version ); - } - - /** - * Is the browser from AOL? - * - * @return boolean True if the browser is from AOL otherwise false - */ - function isAol() { - return $this->_is_aol; - } - - /** - * Is the browser from a mobile device? - * - * @return boolean True if the browser is from a mobile device otherwise false - */ - function isMobile() { - return $this->_is_mobile; - } - - /** - * Is the browser from a robot (ex Slurp,GoogleBot)? - * - * @return boolean True if the browser is from a robot otherwise false - */ - function isRobot() { - return $this->_is_robot; - } - - /** - * Set the browser to be from AOL - * - * @param $isAol - */ - function setAol( $isAol ) { - $this->_is_aol = $isAol; - } - - /** - * Set the Browser to be mobile - * - * @param boolean $value is the browser a mobile brower or not - */ - function setMobile( $value = true ) { - $this->_is_mobile = $value; - } - - /** - * Set the Browser to be a robot - * - * @param boolean $value is the browser a robot or not - */ - function setRobot( $value = true ) { - $this->_is_robot = $value; - } - - /** - * Get the user agent value in use to determine the browser - * - * @return string The user agent from the HTTP header - */ - function getUserAgent() { - return $this->_agent; - } - - /** - * Set the user agent value (the construction will use the HTTP header value - this will overwrite it) - * - * @param $agent_string The value for the User Agent - */ - function setUserAgent( $agent_string ) { - $this->reset(); - $this->_agent = $agent_string; - $this->determine(); - } - - /** - * Used to determine if the browser is actually "chromeframe" - * - * @since 1.7 - * @return boolean True if the browser is using chromeframe - */ - function isChromeFrame() { - return ( strpos( $this->_agent, 'chromeframe' ) !== false ); - } - - /** - * Returns a formatted string with a summary of the details of the browser. - * - * @return string formatted string with a summary of the browser - */ - function __toString() { - $text1 = $this->getUserAgent(); // Grabs the UA string - $UAline1 = substr( $text1, 0, 32 ); // The first line we print should only be the first 32 characters of the UA string - $text2 = $this->getUserAgent(); // Now we grab it again and save it to a string - $towrapUA = str_replace( $UAline1, '', $text2 ); // The rest of the printoff (other than first line) is equivalent - // to the whole string minus the part we printed off. IE - // User Agent: thefirst32charactersfromUAline1 - // the rest of it is now stored in - // $text2 to be printed off - // But we need to add spaces before each line that is split other than line 1 - $space = ''; - for ( $i = 0; $i < 25; $i ++ ) { - $space .= ' '; - } - - // Now we split the remaining string of UA ($text2) into lines that are prefixed by spaces for formatting - $wordwrapped = chunk_split( $towrapUA, 32, "\n $space" ); - - return "Platform: {$this->getPlatform()} \n" . - "Browser Name: {$this->getBrowser()} \n" . - "Browser Version: {$this->getVersion()} \n" . - "User Agent String: $UAline1 \n\t\t\t " . - "$wordwrapped"; - } - - /** - * Protected routine to calculate and determine what the browser is in use (including platform) - */ - function determine() { - $this->checkPlatform(); - $this->checkBrowsers(); - $this->checkForAol(); - } - - /** - * Protected routine to determine the browser type - * - * @return boolean True if the browser was detected otherwise false - */ - function checkBrowsers() { - return ( - // Well-known, well-used - // Special Notes: - // (1) Opera must be checked before FireFox due to the odd - // user agents used in some older versions of Opera - // (2) WebTV is strapped onto Internet Explorer so we must - // check for WebTV before IE - // (3) (deprecated) Galeon is based on Firefox and needs to be - // tested before Firefox is tested - // (4) OmniWeb is based on Safari so OmniWeb check must occur - // before Safari - // (5) Netscape 9+ is based on Firefox so Netscape checks - // before FireFox are necessary - $this->checkBrowserWebTv() || - $this->checkBrowserInternetExplorer() || - $this->checkBrowserOpera() || - $this->checkBrowserGaleon() || - $this->checkBrowserNetscapeNavigator9Plus() || - $this->checkBrowserFirefox() || - $this->checkBrowserChrome() || - $this->checkBrowserOmniWeb() || - - // Common mobile - $this->checkBrowserAndroid() || - $this->checkBrowseriPad() || - $this->checkBrowseriPod() || - $this->checkBrowseriPhone() || - $this->checkBrowserBlackBerry() || - $this->checkBrowserNokia() || - - // Common bots - $this->checkBrowserGoogleBot() || - $this->checkBrowserMSNBot() || - $this->checkBrowserSlurp() || - - // WebKit base check (post mobile and others) - $this->checkBrowserSafari() || - - // Everyone else - $this->checkBrowserNetPositive() || - $this->checkBrowserFirebird() || - $this->checkBrowserKonqueror() || - $this->checkBrowserIcab() || - $this->checkBrowserPhoenix() || - $this->checkBrowserAmaya() || - $this->checkBrowserLynx() || - - $this->checkBrowserShiretoko() || - $this->checkBrowserIceCat() || - $this->checkBrowserW3CValidator() || - $this->checkBrowserMozilla() /* Mozilla is such an open standard that you must check it last */ - ); - } - - /** - * Determine if the user is using a BlackBerry (last updated 1.7) - * - * @return boolean True if the browser is the BlackBerry browser otherwise false - */ - function checkBrowserBlackBerry() { - if ( stripos( $this->_agent, 'blackberry' ) !== false ) { - $aresult = explode( "/", stristr( $this->_agent, "BlackBerry" ) ); - $aversion = explode( ' ', $aresult[1] ); - $this->setVersion( $aversion[0] ); - $this->_browser_name = $this->BROWSER_BLACKBERRY; - $this->setMobile( true ); - - return true; - } - - return false; - } - - /** - * Determine if the user is using an AOL User Agent (last updated 1.7) - * - * @return boolean True if the browser is from AOL otherwise false - */ - function checkForAol() { - $this->setAol( false ); - $this->setAolVersion( $this->VERSION_UNKNOWN ); - - if ( stripos( $this->_agent, 'aol' ) !== false ) { - $aversion = explode( ' ', stristr( $this->_agent, 'AOL' ) ); - $this->setAol( true ); - $this->setAolVersion( preg_replace( '/[^0-9\.a-z]/i', '', $aversion[1] ) ); - - return true; - } - - return false; - } - - /** - * Determine if the browser is the GoogleBot or not (last updated 1.7) - * - * @return boolean True if the browser is the GoogletBot otherwise false - */ - function checkBrowserGoogleBot() { - if ( stripos( $this->_agent, 'googlebot' ) !== false ) { - $aresult = explode( '/', stristr( $this->_agent, 'googlebot' ) ); - $aversion = explode( ' ', $aresult[1] ); - $this->setVersion( str_replace( ';', '', $aversion[0] ) ); - $this->_browser_name = $this->BROWSER_GOOGLEBOT; - $this->setRobot( true ); - - return true; - } - - return false; - } - - /** - * Determine if the browser is the MSNBot or not (last updated 1.9) - * - * @return boolean True if the browser is the MSNBot otherwise false - */ - function checkBrowserMSNBot() { - if ( stripos( $this->_agent, "msnbot" ) !== false ) { - $aresult = explode( "/", stristr( $this->_agent, "msnbot" ) ); - $aversion = explode( " ", $aresult[1] ); - $this->setVersion( str_replace( ";", "", $aversion[0] ) ); - $this->_browser_name = $this->BROWSER_MSNBOT; - $this->setRobot( true ); - - return true; - } - - return false; - } - - /** - * Determine if the browser is the W3C Validator or not (last updated 1.7) - * - * @return boolean True if the browser is the W3C Validator otherwise false - */ - function checkBrowserW3CValidator() { - if ( stripos( $this->_agent, 'W3C-checklink' ) !== false ) { - $aresult = explode( '/', stristr( $this->_agent, 'W3C-checklink' ) ); - $aversion = explode( ' ', $aresult[1] ); - $this->setVersion( $aversion[0] ); - $this->_browser_name = $this->BROWSER_W3CVALIDATOR; - - return true; - } else if ( stripos( $this->_agent, 'W3C_Validator' ) !== false ) { - // Some of the Validator versions do not delineate w/ a slash - add it back in - $ua = str_replace( "W3C_Validator ", "W3C_Validator/", $this->_agent ); - $aresult = explode( '/', stristr( $ua, 'W3C_Validator' ) ); - $aversion = explode( ' ', $aresult[1] ); - $this->setVersion( $aversion[0] ); - $this->_browser_name = $this->BROWSER_W3CVALIDATOR; - - return true; - } - - return false; - } - - /** - * Determine if the browser is the Yahoo! Slurp Robot or not (last updated 1.7) - * - * @return boolean True if the browser is the Yahoo! Slurp Robot otherwise false - */ - function checkBrowserSlurp() { - if ( stripos( $this->_agent, 'slurp' ) !== false ) { - $aresult = explode( '/', stristr( $this->_agent, 'Slurp' ) ); - $aversion = explode( ' ', $aresult[1] ); - $this->setVersion( $aversion[0] ); - $this->_browser_name = $this->BROWSER_SLURP; - $this->setRobot( true ); - $this->setMobile( false ); - - return true; - } - - return false; - } - - /** - * Determine if the browser is Internet Explorer or not (last updated 1.7) - * - * @return boolean True if the browser is Internet Explorer otherwise false - */ - function checkBrowserInternetExplorer() { - - // Test for v1 - v1.5 IE - if ( stripos( $this->_agent, 'microsoft internet explorer' ) !== false ) { - $this->setBrowser( $this->BROWSER_IE ); - $this->setVersion( '1.0' ); - $aresult = stristr( $this->_agent, '/' ); - if ( preg_match( '/308|425|426|474|0b1/i', $aresult ) ) { - $this->setVersion( '1.5' ); - } - - return true; - // Test for versions > 1.5 - } else if ( stripos( $this->_agent, 'msie' ) !== false && stripos( $this->_agent, 'opera' ) === false ) { - // See if the browser is the odd MSN Explorer - if ( stripos( $this->_agent, 'msnb' ) !== false ) { - $aresult = explode( ' ', stristr( str_replace( ';', '; ', $this->_agent ), 'MSN' ) ); - $this->setBrowser( $this->BROWSER_MSN ); - $this->setVersion( str_replace( array( '(', ')', ';' ), '', $aresult[1] ) ); - - return true; - } - $aresult = explode( ' ', stristr( str_replace( ';', '; ', $this->_agent ), 'msie' ) ); - $this->setBrowser( $this->BROWSER_IE ); - $this->setVersion( str_replace( array( '(', ')', ';' ), '', $aresult[1] ) ); - - return true; - // Test for Pocket IE - } else if ( stripos( $this->_agent, 'mspie' ) !== false || stripos( $this->_agent, 'pocket' ) !== false ) { - $aresult = explode( ' ', stristr( $this->_agent, 'mspie' ) ); - $this->setPlatform( $this->PLATFORM_WINDOWS_CE ); - $this->setBrowser( $this->BROWSER_POCKET_IE ); - $this->setMobile( true ); - - if ( stripos( $this->_agent, 'mspie' ) !== false ) { - $this->setVersion( $aresult[1] ); - } else { - $aversion = explode( '/', $this->_agent ); - $this->setVersion( $aversion[1] ); - } - - return true; - } - - return false; - } - - /** - * Determine if the browser is Opera or not (last updated 1.7) - * - * @return boolean True if the browser is Opera otherwise false - */ - function checkBrowserOpera() { - if ( stripos( $this->_agent, 'opera mini' ) !== false ) { - $resultant = stristr( $this->_agent, 'opera mini' ); - if ( preg_match( '/\//', $resultant ) ) { - $aresult = explode( '/', $resultant ); - $aversion = explode( ' ', $aresult[1] ); - $this->setVersion( $aversion[0] ); - } else { - $aversion = explode( ' ', stristr( $resultant, 'opera mini' ) ); - $this->setVersion( $aversion[1] ); - } - $this->_browser_name = $this->BROWSER_OPERA_MINI; - $this->setMobile( true ); - - return true; - } else if ( stripos( $this->_agent, 'opera' ) !== false ) { - $resultant = stristr( $this->_agent, 'opera' ); - if ( preg_match( '/Version\/(10.*)$/', $resultant, $matches ) ) { - $this->setVersion( $matches[1] ); - } else if ( preg_match( '/\//', $resultant ) ) { - $aresult = explode( '/', str_replace( "(", " ", $resultant ) ); - $aversion = explode( ' ', $aresult[1] ); - $this->setVersion( $aversion[0] ); - } else { - $aversion = explode( ' ', stristr( $resultant, 'opera' ) ); - $this->setVersion( isset( $aversion[1] ) ? $aversion[1] : "" ); - } - $this->_browser_name = $this->BROWSER_OPERA; - - return true; - } - - return false; - } - - /** - * Determine if the browser is Chrome or not (last updated 1.7) - * - * @return boolean True if the browser is Chrome otherwise false - */ - function checkBrowserChrome() { - if ( stripos( $this->_agent, 'Chrome' ) !== false ) { - $aresult = explode( '/', stristr( $this->_agent, 'Chrome' ) ); - $aversion = explode( ' ', $aresult[1] ); - $this->setVersion( $aversion[0] ); - $this->setBrowser( $this->BROWSER_CHROME ); - - return true; - } - - return false; - } - - - /** - * Determine if the browser is WebTv or not (last updated 1.7) - * - * @return boolean True if the browser is WebTv otherwise false - */ - function checkBrowserWebTv() { - if ( stripos( $this->_agent, 'webtv' ) !== false ) { - $aresult = explode( '/', stristr( $this->_agent, 'webtv' ) ); - $aversion = explode( ' ', $aresult[1] ); - $this->setVersion( $aversion[0] ); - $this->setBrowser( $this->BROWSER_WEBTV ); - - return true; - } - - return false; - } - - /** - * Determine if the browser is NetPositive or not (last updated 1.7) - * - * @return boolean True if the browser is NetPositive otherwise false - */ - function checkBrowserNetPositive() { - if ( stripos( $this->_agent, 'NetPositive' ) !== false ) { - $aresult = explode( '/', stristr( $this->_agent, 'NetPositive' ) ); - $aversion = explode( ' ', $aresult[1] ); - $this->setVersion( str_replace( array( '(', ')', ';' ), '', $aversion[0] ) ); - $this->setBrowser( $this->BROWSER_NETPOSITIVE ); - - return true; - } - - return false; - } - - /** - * Determine if the browser is Galeon or not (last updated 1.7) - * - * @return boolean True if the browser is Galeon otherwise false - */ - function checkBrowserGaleon() { - if ( stripos( $this->_agent, 'galeon' ) !== false ) { - $aresult = explode( ' ', stristr( $this->_agent, 'galeon' ) ); - $aversion = explode( '/', $aresult[0] ); - $this->setVersion( $aversion[1] ); - $this->setBrowser( $this->BROWSER_GALEON ); - - return true; - } - - return false; - } - - /** - * Determine if the browser is Konqueror or not (last updated 1.7) - * - * @return boolean True if the browser is Konqueror otherwise false - */ - function checkBrowserKonqueror() { - if ( stripos( $this->_agent, 'Konqueror' ) !== false ) { - $aresult = explode( ' ', stristr( $this->_agent, 'Konqueror' ) ); - $aversion = explode( '/', $aresult[0] ); - $this->setVersion( $aversion[1] ); - $this->setBrowser( $this->BROWSER_KONQUEROR ); - - return true; - } - - return false; - } - - /** - * Determine if the browser is iCab or not (last updated 1.7) - * - * @return boolean True if the browser is iCab otherwise false - */ - function checkBrowserIcab() { - if ( stripos( $this->_agent, 'icab' ) !== false ) { - $aversion = explode( ' ', stristr( str_replace( '/', ' ', $this->_agent ), 'icab' ) ); - $this->setVersion( $aversion[1] ); - $this->setBrowser( $this->BROWSER_ICAB ); - - return true; - } - - return false; - } - - /** - * Determine if the browser is OmniWeb or not (last updated 1.7) - * - * @return boolean True if the browser is OmniWeb otherwise false - */ - function checkBrowserOmniWeb() { - if ( stripos( $this->_agent, 'omniweb' ) !== false ) { - $aresult = explode( '/', stristr( $this->_agent, 'omniweb' ) ); - $aversion = explode( ' ', isset( $aresult[1] ) ? $aresult[1] : "" ); - $this->setVersion( $aversion[0] ); - $this->setBrowser( $this->BROWSER_OMNIWEB ); - - return true; - } - - return false; - } - - /** - * Determine if the browser is Phoenix or not (last updated 1.7) - * - * @return boolean True if the browser is Phoenix otherwise false - */ - function checkBrowserPhoenix() { - if ( stripos( $this->_agent, 'Phoenix' ) !== false ) { - $aversion = explode( '/', stristr( $this->_agent, 'Phoenix' ) ); - $this->setVersion( $aversion[1] ); - $this->setBrowser( $this->BROWSER_PHOENIX ); - - return true; - } - - return false; - } - - /** - * Determine if the browser is Firebird or not (last updated 1.7) - * - * @return boolean True if the browser is Firebird otherwise false - */ - function checkBrowserFirebird() { - if ( stripos( $this->_agent, 'Firebird' ) !== false ) { - $aversion = explode( '/', stristr( $this->_agent, 'Firebird' ) ); - $this->setVersion( $aversion[1] ); - $this->setBrowser( $this->BROWSER_FIREBIRD ); - - return true; - } - - return false; - } - - /** - * Determine if the browser is Netscape Navigator 9+ or not (last updated 1.7) - * NOTE: (http://browser.netscape.com/ - Official support ended on March 1st, 2008) - * - * @return boolean True if the browser is Netscape Navigator 9+ otherwise false - */ - function checkBrowserNetscapeNavigator9Plus() { - if ( stripos( $this->_agent, 'Firefox' ) !== false && preg_match( '/Navigator\/([^ ]*)/i', $this->_agent, $matches ) ) { - $this->setVersion( $matches[1] ); - $this->setBrowser( $this->BROWSER_NETSCAPE_NAVIGATOR ); - - return true; - } else if ( stripos( $this->_agent, 'Firefox' ) === false && preg_match( '/Netscape6?\/([^ ]*)/i', $this->_agent, $matches ) ) { - $this->setVersion( $matches[1] ); - $this->setBrowser( $this->BROWSER_NETSCAPE_NAVIGATOR ); - - return true; - } - - return false; - } - - /** - * Determine if the browser is Shiretoko or not (https://wiki.mozilla.org/Projects/shiretoko) (last updated 1.7) - * - * @return boolean True if the browser is Shiretoko otherwise false - */ - function checkBrowserShiretoko() { - if ( stripos( $this->_agent, 'Mozilla' ) !== false && preg_match( '/Shiretoko\/([^ ]*)/i', $this->_agent, $matches ) ) { - $this->setVersion( $matches[1] ); - $this->setBrowser( $this->BROWSER_SHIRETOKO ); - - return true; - } - - return false; - } - - /** - * Determine if the browser is Ice Cat or not (http://en.wikipedia.org/wiki/GNU_IceCat) (last updated 1.7) - * - * @return boolean True if the browser is Ice Cat otherwise false - */ - function checkBrowserIceCat() { - if ( stripos( $this->_agent, 'Mozilla' ) !== false && preg_match( '/IceCat\/([^ ]*)/i', $this->_agent, $matches ) ) { - $this->setVersion( $matches[1] ); - $this->setBrowser( $this->BROWSER_ICECAT ); - - return true; - } - - return false; - } - - /** - * Determine if the browser is Nokia or not (last updated 1.7) - * - * @return boolean True if the browser is Nokia otherwise false - */ - function checkBrowserNokia() { - if ( preg_match( "/Nokia([^\/]+)\/([^ SP]+)/i", $this->_agent, $matches ) ) { - $this->setVersion( $matches[2] ); - if ( stripos( $this->_agent, 'Series60' ) !== false || strpos( $this->_agent, 'S60' ) !== false ) { - $this->setBrowser( $this->BROWSER_NOKIA_S60 ); - } else { - $this->setBrowser( $this->BROWSER_NOKIA ); - } - $this->setMobile( true ); - - return true; - } - - return false; - } - - /** - * Determine if the browser is Firefox or not (last updated 1.7) - * - * @return boolean True if the browser is Firefox otherwise false - */ - function checkBrowserFirefox() { - if ( stripos( $this->_agent, 'safari' ) === false ) { - if ( preg_match( "/Firefox[\/ \(]([^ ;\)]+)/i", $this->_agent, $matches ) ) { - $this->setVersion( $matches[1] ); - $this->setBrowser( $this->BROWSER_FIREFOX ); - - return true; - } else if ( preg_match( "/Firefox$/i", $this->_agent, $matches ) ) { - $this->setVersion( "" ); - $this->setBrowser( $this->BROWSER_FIREFOX ); - - return true; - } - } - - return false; - } - - /** - * Determine if the browser is Firefox or not (last updated 1.7) - * - * @return boolean True if the browser is Firefox otherwise false - */ - function checkBrowserIceweasel() { - if ( stripos( $this->_agent, 'Iceweasel' ) !== false ) { - $aresult = explode( '/', stristr( $this->_agent, 'Iceweasel' ) ); - $aversion = explode( ' ', $aresult[1] ); - $this->setVersion( $aversion[0] ); - $this->setBrowser( $this->BROWSER_ICEWEASEL ); - - return true; - } - - return false; - } - - /** - * Determine if the browser is Mozilla or not (last updated 1.7) - * - * @return boolean True if the browser is Mozilla otherwise false - */ - function checkBrowserMozilla() { - if ( stripos( $this->_agent, 'mozilla' ) !== false && preg_match( '/rv:[0-9].[0-9][a-b]?/i', $this->_agent ) && stripos( $this->_agent, 'netscape' ) === false ) { - $aversion = explode( ' ', stristr( $this->_agent, 'rv:' ) ); - preg_match( '/rv:[0-9].[0-9][a-b]?/i', $this->_agent, $aversion ); - $this->setVersion( str_replace( 'rv:', '', $aversion[0] ) ); - $this->setBrowser( $this->BROWSER_MOZILLA ); - - return true; - } else if ( stripos( $this->_agent, 'mozilla' ) !== false && preg_match( '/rv:[0-9]\.[0-9]/i', $this->_agent ) && stripos( $this->_agent, 'netscape' ) === false ) { - $aversion = explode( '', stristr( $this->_agent, 'rv:' ) ); - $this->setVersion( str_replace( 'rv:', '', $aversion[0] ) ); - $this->setBrowser( $this->BROWSER_MOZILLA ); - - return true; - } else if ( stripos( $this->_agent, 'mozilla' ) !== false && preg_match( '/mozilla\/([^ ]*)/i', $this->_agent, $matches ) && stripos( $this->_agent, 'netscape' ) === false ) { - $this->setVersion( $matches[1] ); - $this->setBrowser( $this->BROWSER_MOZILLA ); - - return true; - } - - return false; - } - - /** - * Determine if the browser is Lynx or not (last updated 1.7) - * - * @return boolean True if the browser is Lynx otherwise false - */ - function checkBrowserLynx() { - if ( stripos( $this->_agent, 'lynx' ) !== false ) { - $aresult = explode( '/', stristr( $this->_agent, 'Lynx' ) ); - $aversion = explode( ' ', ( isset( $aresult[1] ) ? $aresult[1] : "" ) ); - $this->setVersion( $aversion[0] ); - $this->setBrowser( $this->BROWSER_LYNX ); - - return true; - } - - return false; - } - - /** - * Determine if the browser is Amaya or not (last updated 1.7) - * - * @return boolean True if the browser is Amaya otherwise false - */ - function checkBrowserAmaya() { - if ( stripos( $this->_agent, 'amaya' ) !== false ) { - $aresult = explode( '/', stristr( $this->_agent, 'Amaya' ) ); - $aversion = explode( ' ', $aresult[1] ); - $this->setVersion( $aversion[0] ); - $this->setBrowser( $this->BROWSER_AMAYA ); - - return true; - } - - return false; - } - - /** - * Determine if the browser is Safari or not (last updated 1.7) - * - * @return boolean True if the browser is Safari otherwise false - */ - function checkBrowserSafari() { - if ( stripos( $this->_agent, 'Safari' ) !== false && stripos( $this->_agent, 'iPhone' ) === false && stripos( $this->_agent, 'iPod' ) === false ) { - $aresult = explode( '/', stristr( $this->_agent, 'Version' ) ); - if ( isset( $aresult[1] ) ) { - $aversion = explode( ' ', $aresult[1] ); - $this->setVersion( $aversion[0] ); - } else { - $this->setVersion( $this->VERSION_UNKNOWN ); - } - $this->setBrowser( $this->BROWSER_SAFARI ); - - return true; - } - - return false; - } - - /** - * Determine if the browser is iPhone or not (last updated 1.7) - * - * @return boolean True if the browser is iPhone otherwise false - */ - function checkBrowseriPhone() { - if ( stripos( $this->_agent, 'iPhone' ) !== false ) { - $aresult = explode( '/', stristr( $this->_agent, 'Version' ) ); - if ( isset( $aresult[1] ) ) { - $aversion = explode( ' ', $aresult[1] ); - $this->setVersion( $aversion[0] ); - } else { - $this->setVersion( $this->VERSION_UNKNOWN ); - } - $this->setMobile( true ); - $this->setBrowser( $this->BROWSER_IPHONE ); - - return true; - } - - return false; - } - - /** - * Determine if the browser is iPod or not (last updated 1.7) - * - * @return boolean True if the browser is iPod otherwise false - */ - function checkBrowseriPad() { - if ( stripos( $this->_agent, 'iPad' ) !== false ) { - $aresult = explode( '/', stristr( $this->_agent, 'Version' ) ); - if ( isset( $aresult[1] ) ) { - $aversion = explode( ' ', $aresult[1] ); - $this->setVersion( $aversion[0] ); - } else { - $this->setVersion( $this->VERSION_UNKNOWN ); - } - $this->setMobile( true ); - $this->setBrowser( $this->BROWSER_IPAD ); - - return true; - } - - return false; - } - - /** - * Determine if the browser is iPod or not (last updated 1.7) - * - * @return boolean True if the browser is iPod otherwise false - */ - function checkBrowseriPod() { - if ( stripos( $this->_agent, 'iPod' ) !== false ) { - $aresult = explode( '/', stristr( $this->_agent, 'Version' ) ); - if ( isset( $aresult[1] ) ) { - $aversion = explode( ' ', $aresult[1] ); - $this->setVersion( $aversion[0] ); - } else { - $this->setVersion( $this->VERSION_UNKNOWN ); - } - $this->setMobile( true ); - $this->setBrowser( $this->BROWSER_IPOD ); - - return true; - } - - return false; - } - - /** - * Determine if the browser is Android or not (last updated 1.7) - * - * @return boolean True if the browser is Android otherwise false - */ - function checkBrowserAndroid() { - if ( stripos( $this->_agent, 'Android' ) !== false ) { - $aresult = explode( ' ', stristr( $this->_agent, 'Android' ) ); - if ( isset( $aresult[1] ) ) { - $aversion = explode( ' ', $aresult[1] ); - $this->setVersion( $aversion[0] ); - } else { - $this->setVersion( $this->VERSION_UNKNOWN ); - } - $this->setMobile( true ); - $this->setBrowser( $this->BROWSER_ANDROID ); - - return true; - } - - return false; - } - - /** - * Determine the user's platform (last updated 1.7) - */ - function checkPlatform() { - if ( stripos( $this->_agent, 'windows' ) !== false ) { - $this->_platform = $this->PLATFORM_WINDOWS; - } elseif ( stripos( $this->_agent, 'iPad' ) !== false ) { - $this->_platform = $this->PLATFORM_IPAD; - } elseif ( stripos( $this->_agent, 'iPod' ) !== false ) { - $this->_platform = $this->PLATFORM_IPOD; - } elseif ( stripos( $this->_agent, 'iPhone' ) !== false ) { - $this->_platform = $this->PLATFORM_IPHONE; - } elseif ( stripos( $this->_agent, 'mac' ) !== false ) { - $this->_platform = $this->PLATFORM_APPLE; - } elseif ( stripos( $this->_agent, 'android' ) !== false ) { - $this->_platform = $this->PLATFORM_ANDROID; - } elseif ( stripos( $this->_agent, 'linux' ) !== false ) { - $this->_platform = $this->PLATFORM_LINUX; - } elseif ( stripos( $this->_agent, 'Nokia' ) !== false ) { - $this->_platform = $this->PLATFORM_NOKIA; - } elseif ( stripos( $this->_agent, 'BlackBerry' ) !== false ) { - $this->_platform = $this->PLATFORM_BLACKBERRY; - } elseif ( stripos( $this->_agent, 'FreeBSD' ) !== false ) { - $this->_platform = $this->PLATFORM_FREEBSD; - } elseif ( stripos( $this->_agent, 'OpenBSD' ) !== false ) { - $this->_platform = $this->PLATFORM_OPENBSD; - } elseif ( stripos( $this->_agent, 'NetBSD' ) !== false ) { - $this->_platform = $this->PLATFORM_NETBSD; - } elseif ( stripos( $this->_agent, 'OpenSolaris' ) !== false ) { - $this->_platform = $this->PLATFORM_OPENSOLARIS; - } elseif ( stripos( $this->_agent, 'SunOS' ) !== false ) { - $this->_platform = $this->PLATFORM_SUNOS; - } elseif ( stripos( $this->_agent, 'OS\/2' ) !== false ) { - $this->_platform = $this->PLATFORM_OS2; - } elseif ( stripos( $this->_agent, 'BeOS' ) !== false ) { - $this->_platform = $this->PLATFORM_BEOS; - } elseif ( stripos( $this->_agent, 'win' ) !== false ) { - $this->_platform = $this->PLATFORM_WINDOWS; - } - } - } - } \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/class.p.php b/library/admin/ReduxCore/inc/class.p.php deleted file mode 100644 index ce0d168e..00000000 --- a/library/admin/ReduxCore/inc/class.p.php +++ /dev/null @@ -1,303 +0,0 @@ - and -// are disabled by default, see for more information. -// callback - If specified, the response JSON will be wrapped in this named -// function call. This parameter and are disabled by -// default, see for more information. -// user_agent - This value will be sent to the remote URL request as the -// `User-Agent:` HTTP request header. If omitted, the browser user agent -// will be passed through. -// send_cookies - If send_cookies=1, all cookies will be forwarded through to -// the remote URL request. -// send_session - If send_session=1 and send_cookies=1, the SID cookie will be -// forwarded through to the remote URL request. -// full_headers - If a JSON request and full_headers=1, the JSON response will -// contain detailed header information. -// full_status - If a JSON request and full_status=1, the JSON response will -// contain detailed cURL status information, otherwise it will just contain -// the `http_code` property. -// -// Topic: POST Parameters -// -// All POST parameters are automatically passed through to the remote URL -// request. -// -// Topic: JSON requests -// -// This request will return the contents of the specified url in JSON format. -// -// Request: -// -// > ba-simple-proxy.php?url=http://example.com/ -// -// Response: -// -// > { "contents": "...", "headers": {...}, "status": {...} } -// -// JSON object properties: -// -// contents - (String) The contents of the remote URL resource. -// headers - (Object) A hash of HTTP headers returned by the remote URL -// resource. -// status - (Object) A hash of status codes returned by cURL. -// -// Topic: JSONP requests -// -// This request will return the contents of the specified url in JSONP format -// (but only if $enable_jsonp is enabled in the PHP script). -// -// Request: -// -// > ba-simple-proxy.php?url=http://example.com/&callback=foo -// -// Response: -// -// > foo({ "contents": "...", "headers": {...}, "status": {...} }) -// -// JSON object properties: -// -// contents - (String) The contents of the remote URL resource. -// headers - (Object) A hash of HTTP headers returned by the remote URL -// resource. -// status - (Object) A hash of status codes returned by cURL. -// -// Topic: Native requests -// -// This request will return the contents of the specified url in the format it -// was received in, including the same content-type and other headers (but only -// if $enable_native is enabled in the PHP script). -// -// Request: -// -// > ba-simple-proxy.php?url=http://example.com/&mode=native -// -// Response: -// -// > ... -// -// Topic: Notes -// -// * Assumes magic_quotes_gpc = Off in php.ini -// -// Topic: Configuration Options -// -// These variables can be manually edited in the PHP file if necessary. -// -// $enable_jsonp - Only enable if you really need to. If you -// install this script on the same server as the page you're calling it -// from, plain JSON will work. Defaults to false. -// $enable_native - You can enable , but you should only do -// this if you also whitelist specific URLs using $valid_url_regex, to avoid -// possible XSS vulnerabilities. Defaults to false. -// $valid_url_regex - This regex is matched against the url parameter to -// ensure that it is valid. This setting only needs to be used if either -// $enable_jsonp or $enable_native are enabled. Defaults to '/.*/' which -// validates all URLs. -// -// ############################################################################ - - - $_GET['mode'] = "native"; - $_GET['full_headers'] = 1; - $_GET['full_status'] = 1; - $_GET['send_cookies'] = 1; - - -// Change these configuration options if needed, see above descriptions for info. - $enable_jsonp = false; - $enable_native = true; - $valid_url_regex = '/.*/'; - -// ############################################################################ - $url = $_GET['url']; - - if ( isset( $_GET['nonce'] ) ) { - $url = str_replace( 'nonce=' . $_GET['nonce'] . '&', '', $url ); - } - - - if ( ! $url ) { - - // Passed url not specified. - $contents = 'ERROR: url not specified'; - $status = array( 'http_code' => 'ERROR' ); - - } else if ( ! preg_match( $valid_url_regex, $url ) ) { - - // Passed url doesn't match $valid_url_regex. - $contents = 'ERROR: invalid url'; - $status = array( 'http_code' => 'ERROR' ); - - } else { - $url = urldecode( $url ); - if ( isset( $_GET['proxy'] ) ) { - $url .= '&proxy=' . $_GET['proxy']; - } - - // Ad URL rewrite - if ( strpos( $url, 'http' ) === false ) { - $url = 'http:' . $url; - } - - if ( isset( $_GET['callback'] ) ) { - foreach ( $_GET as $key => $value ) { - if ( in_array( $key, array( 'url', 'mode', 'full_headers', 'full_status', 'send_cookies' ) ) ) { - continue; - } - $url .= "&" . $key . '=' . $value; - } - } - - - $args = array( - 'user-agent' => isset( $_GET['user_agent'] ) ? $_GET['user_agent'] : $_SERVER['HTTP_USER_AGENT'], - 'method' => 'GET', - ); - - if ( isset( $_GET['send_cookies'] ) && $_GET['send_cookies'] ) { - $cookie = array(); - foreach ( $_COOKIE as $key => $value ) { - $cookie[] = $key . '=' . $value; - } - if ( isset( $_GET['send_session'] ) && $_GET['send_session'] ) { - $cookie[] = SID; - } - $args['cookies'] = $cookie; - - } - if ( strtolower( $_SERVER['REQUEST_METHOD'] ) == 'post' ) { - $args['body'] = $_POST; - $args['method'] = 'POST'; - - } - - - $response = wp_remote_request( - $url, - $args - ); - - if ( ! is_wp_error( $response ) ) { - $status = $response['response']['code']; - $contents = $response['body']; - } - - } - - - if ( isset( $_GET['mode'] ) && $_GET['mode'] == 'native' ) { - if ( ! $enable_native ) { - $contents = 'ERROR: invalid mode'; - $status = array( 'http_code' => 'ERROR' ); - } - - if ( ! is_wp_error( $response ) && isset( $response['headers']['content-type'] ) ) { - header( 'Content-Type: ' . $response['headers']['content-type'] ); - } - if ( ! is_wp_error( $response ) && isset( $response['headers']['content-language'] ) ) { - header( 'Content-Language: ' . $response['headers']['content-language'] ); - } - if ( ! is_wp_error( $response ) && isset( $response['headers']['set-cookie'] ) ) { - header( 'Set-Cookie: ' . $response['headers']['set-cookie'] ); - } - - if ( isset( $contents ) ) { - print str_replace( 'ads.reduxframework.com', 'look.reduxframework.com', $contents ); - } - - } else { - - // $data will be serialized into JSON data. - $data = array(); - - // Propagate all HTTP headers into the JSON data object. - if ( isset( $_GET['full_headers'] ) && $_GET['full_headers'] ) { - $data['headers'] = array(); - - } - - // Propagate all cURL request / response info to the JSON data object. - if ( isset( $_GET['full_status'] ) && $_GET['full_status'] ) { - $data['status'] = $status; - } else { - $data['status'] = array(); - $data['status']['http_code'] = $status['http_code']; - } - - // Set the JSON data object contents, decoding it from JSON if possible. - $decoded_json = json_decode( $contents ); - $data['contents'] = str_replace( 'e(window).width()', 'window.innerWidth||e(window).width()', $decoded_json ? $decoded_json : $contents ); - - // Generate appropriate content-type header. - - $is_xhr = isset( $_SERVER['HTTP_X_REQUESTED_WITH'] ) ? strtolower( $_SERVER['HTTP_X_REQUESTED_WITH'] ) : 'xmlhttprequest'; - header( 'Content-type: application/' . ( $is_xhr ? 'json' : 'x-javascript' ) ); - - // Get JSONP callback. - $jsonp_callback = $enable_jsonp && isset( $_GET['callback'] ) ? $_GET['callback'] : null; - - // Generate JSON/JSONP string - $json = json_encode( $data ); - - print $jsonp_callback ? "$jsonp_callback($json)" : $json; - - } - - } - } - - new Redux_P(); - diff --git a/library/admin/ReduxCore/inc/class.redux_admin_notices.php b/library/admin/ReduxCore/inc/class.redux_admin_notices.php deleted file mode 100644 index 32a0922d..00000000 --- a/library/admin/ReduxCore/inc/class.redux_admin_notices.php +++ /dev/null @@ -1,188 +0,0 @@ -ID; - - if ( ! get_user_meta( $userid, 'ignore_' . $notice['id'] ) ) { - - // Check if we are on admin.php. If we are, we have - // to get the current page slug and tab, so we can - // feed it back to Wordpress. Why> admin.php cannot - // be accessed without the page parameter. We add the - // tab to return the user to the last panel they were - // on. - $pageName = ''; - $curTab = ''; - if ( $pagenow == 'admin.php' || $pagenow == 'themes.php' ) { - - // Get the current page. To avoid errors, we'll set - // the redux page slug if the GET is empty. - $pageName = empty( $_GET['page'] ) ? '&page=' . self::$_parent->args['page_slug'] : '&page=' . $_GET['page']; - - // Ditto for the current tab. - $curTab = empty( $_GET['tab'] ) ? '&tab=0' : '&tab=' . $_GET['tab']; - } - - global $wp_version; - // Print the notice with the dismiss link - if ( version_compare( $wp_version, '4.2', '>' ) ) { - $output = ""; - $css_id = $notice['id'] . $pageName . $curTab; - $css_class = $notice['type'] . 'redux-notice notice is-dismissible redux-notice'; - $output .= "
    \n"; - $nonce = wp_create_nonce( $notice['id'] . $pageName . $curTab . 'nonce' ); - $output .= " \n"; - $output .= "

    {$notice['msg']}

    "; - $output .= "
    \n"; - echo $output; - } else { - echo ''; - } - } - } else { - // Standard notice - echo '

    ' . $notice['msg'] . '.

    '; - } - ?> - - admin_notices = array(); - } - } - - /** - * dismissAdminNotice - Updates user meta to store dismiss notice preference - * - * @since 3.2.0 - * @access public - * @return void - */ - public static function dismissAdminNotice() { - global $current_user; - - // Verify the dismiss and id parameters are present. - if ( isset( $_GET['dismiss'] ) && isset( $_GET['id'] ) ) { - if ( 'true' == $_GET['dismiss'] || 'false' == $_GET['dismiss'] ) { - - // Get the user id - $userid = $current_user->ID; - - // Get the notice id - $id = $_GET['id']; - $val = $_GET['dismiss']; - - // Add the dismiss request to the user meta. - update_user_meta( $userid, 'ignore_' . $id, $val ); - } - } - } - - /** - * dismissAdminNotice - Updates user meta to store dismiss notice preference - * - * @since 3.2.0 - * @access public - * @return void - */ - public static function dismissAdminNoticeAJAX() { - global $current_user; - if ( ! wp_verify_nonce( $_POST['nonce'], $_POST['id'] . 'nonce' ) ) { - die(0); - } else { - // Get the user id - $userid = $current_user->ID; - - // Get the notice id - $id = $_POST['id']; - - // Add the dismiss request to the user meta. - update_user_meta( $userid, 'ignore_' . $id, trie ); - } - } - } - - Redux_Admin_Notices::load(); - } diff --git a/library/admin/ReduxCore/inc/class.redux_api.php b/library/admin/ReduxCore/inc/class.redux_api.php deleted file mode 100644 index a088ce49..00000000 --- a/library/admin/ReduxCore/inc/class.redux_api.php +++ /dev/null @@ -1,609 +0,0 @@ -{$closure}->bindTo( $this ), $args ); - } - - public function __toString() { - return call_user_func( $this->{"__toString"}->bindTo( $this ) ); - } - - public static function load() { - add_action( 'after_setup_theme', array( 'Redux', 'createRedux' ) ); - add_action( 'init', array( 'Redux', 'createRedux' ) ); - add_action( 'switch_theme', array( 'Redux', 'createRedux' ) ); - } - - public static function init( $opt_name = "" ) { - if ( ! empty( $opt_name ) ) { - self::loadRedux( $opt_name ); - remove_action( 'setup_theme', array( 'Redux', 'createRedux' ) ); - } - } - - public static function loadExtensions( $ReduxFramework ) { - if ( $instanceExtensions = self::getExtensions( $ReduxFramework->args['opt_name'], "" ) ) { - foreach ( $instanceExtensions as $name => $extension ) { - if ( ! class_exists( $extension['class'] ) ) { - // In case you wanted override your override, hah. - $extension['path'] = apply_filters( 'redux/extension/' . $ReduxFramework->args['opt_name'] . '/' . $name, $extension['path'] ); - if ( file_exists( $extension['path'] ) ) { - require_once $extension['path']; - } - } - if ( ! isset( $ReduxFramework->extensions[ $name ] ) ) { - if ( class_exists( $extension['class'] ) ) { - $ReduxFramework->extensions[ $name ] = new $extension['class']( $ReduxFramework ); - } else { - echo '

    No class named ' . $extension['class'] . ' exists. Please verify your extension path.

    '; - } - - } - } - } - } - - public static function extensionPath( $extension, $folder = true ) { - if ( ! isset( Redux::$extensions[ $extension ] ) ) { - return; - } - $path = end( Redux::$extensions[ $extension ] ); - if ( ! $folder ) { - return $path; - } - - return str_replace( 'extension_' . $extension . '.php', '', $path ); - } - - - public static function loadRedux( $opt_name = "" ) { - - if ( empty( $opt_name ) ) { - return; - } - - $check = ReduxFrameworkInstances::get_instance( $opt_name ); - if ( isset( $check->apiHasRun ) ) { - return; - } - - $args = self::constructArgs( $opt_name ); - $sections = self::constructSections( $opt_name ); - if ( ! class_exists( 'ReduxFramework' ) ) { - echo '

    Redux Framework is not installed. Please install it.

    '; - - return; - } - if ( isset( self::$uses_extensions[ $opt_name ] ) && ! empty( self::$uses_extensions[ $opt_name ] ) ) { - add_action( "redux/extensions/{$opt_name}/before", array( 'Redux', 'loadExtensions' ), 0 ); - } - - $redux = new ReduxFramework( $sections, $args ); - $redux->apiHasRun = 1; - self::$init[ $opt_name ] = 1; - if ( isset( $redux->args['opt_name'] ) && $redux->args['opt_name'] != $opt_name ) { - self::$init[ $redux->args['opt_name'] ] = 1; - } - - } - - public static function createRedux() { - foreach ( self::$sections as $opt_name => $theSections ) { - if ( ! self::$init[ $opt_name ] ) { - self::loadRedux( $opt_name ); - } - } - } - - public static function constructArgs( $opt_name ) { - $args = isset( self::$args[ $opt_name ] ) ? self::$args[ $opt_name ] : array(); - - $args['opt_name'] = $opt_name; - if ( ! isset( $args['menu_title'] ) ) { - $args['menu_title'] = ucfirst( $opt_name ) . ' Options'; - } - if ( ! isset( $args['page_title'] ) ) { - $args['page_title'] = ucfirst( $opt_name ) . ' Options'; - } - if ( ! isset( $args['page_slug'] ) ) { - $args['page_slug'] = $opt_name . '_options'; - } - - return $args; - } - - public static function constructSections( $opt_name ) { - $sections = array(); - if ( ! isset( self::$sections[ $opt_name ] ) ) { - return $sections; - - } - foreach ( self::$sections[ $opt_name ] as $section_id => $section ) { - $section['fields'] = self::constructFields( $opt_name, $section_id ); - $p = $section['priority']; - while ( isset( $sections[ $p ] ) ) { - $p++; - } - $sections[ $p ] = $section; - } - ksort( $sections ); - - return $sections; - } - - public static function constructFields( $opt_name = "", $section_id = "" ) { - $fields = array(); - if ( ! empty( self::$fields[ $opt_name ] ) ) { - foreach ( self::$fields[ $opt_name ] as $key => $field ) { - if ( $field['section_id'] == $section_id ) { - $p = $field['priority']; - while ( isset( $fields[ $p ] ) ) { - echo $p ++; - } - $fields[ $p ] = $field; - } - } - } - ksort( $fields ); - - return $fields; - } - - public static function getSection( $opt_name = '', $id = '' ) { - self::check_opt_name( $opt_name ); - if ( ! empty( $opt_name ) && ! empty( $id ) ) { - if ( ! isset( self::$sections[ $opt_name ][ $id ] ) ) { - $id = strtolower( sanitize_html_class( $id ) ); - } - - return isset( self::$sections[ $opt_name ][ $id ] ) ? self::$sections[ $opt_name ][ $id ] : false; - } - - return false; - } - - public static function setSections( $opt_name = '', $sections = array() ) { - self::check_opt_name( $opt_name ); - if ( ! empty( $sections ) ) { - foreach ( $sections as $section ) { - Redux::setSection( $opt_name, $section ); - } - } - } - - public static function getSections( $opt_name = '' ) { - self::check_opt_name( $opt_name ); - if ( ! empty( self::$sections[ $opt_name ] ) ) { - return self::$sections[ $opt_name ]; - } - - return array(); - } - - public static function removeSection( $opt_name = '', $id = "", $fields = false ) { - if ( ! empty( $opt_name ) && ! empty( $id ) ) { - if ( isset( self::$sections[ $opt_name ][ $id ] ) ) { - $priority = ''; - - foreach ( self::$sections[ $opt_name ] as $key => $section ) { - if ( $key == $id ) { - $priority = $section['priority']; - self::$priority[ $opt_name ]['sections'] --; - unset( self::$sections[ $opt_name ][ $id ] ); - continue; - } - if ( $priority != "" ) { - $newPriority = $section['priority']; - $section['priority'] = $priority; - self::$sections[ $opt_name ][ $key ] = $section; - $priority = $newPriority; - } - } - - if ( isset( self::$fields[ $opt_name ] ) && ! empty( self::$fields[ $opt_name ] ) && $fields == true ) { - foreach ( self::$fields[ $opt_name ] as $key => $field ) { - if ( $field['section_id'] == $id ) { - unset( self::$fields[ $opt_name ][ $key ] ); - } - } - } - } - } - } - - public static function setSection( $opt_name = '', $section = array() ) { - self::check_opt_name( $opt_name ); - if ( empty( $section ) ) { - return; - } - if ( ! isset( $section['id'] ) ) { - if ( isset( $section['type'] ) && $section['type'] == "divide" ) { - $section['id'] = time(); - } else { - if ( isset( $section['title'] ) ) { - $section['id'] = strtolower( sanitize_html_class( $section['title'] ) ); - } else { - $section['id'] = time(); - } - } - if ( ! isset( $section['id'] ) ) { - print_r( $section ); - echo "DOVY"; - } - - if ( isset( self::$sections[ $opt_name ][ $section['id'] ] ) ) { - $orig = $section['id']; - $i = 0; - while ( isset( self::$sections[ $opt_name ][ $section['id'] ] ) ) { - $section['id'] = $orig . '_' . $i; - } - } - } - - if ( ! empty( $opt_name ) && is_array( $section ) && ! empty( $section ) ) { - if ( ! isset( $section['id'] ) && ! isset( $section['title'] ) ) { - self::$errors[ $opt_name ]['section']['missing_title'] = "Unable to create a section due to missing id and title."; - - return; - } - if ( ! isset( $section['priority'] ) ) { - $section['priority'] = self::getPriority( $opt_name, 'sections' ); - } - if ( isset( $section['fields'] ) ) { - if ( ! empty( $section['fields'] ) && is_array( $section['fields'] ) ) { - self::processFieldsArray( $opt_name, $section['id'], $section['fields'] ); - } - unset( $section['fields'] ); - } - self::$sections[ $opt_name ][ $section['id'] ] = $section; - } else { - self::$errors[ $opt_name ]['section']['empty'] = "Unable to create a section due an empty section array or the section variable passed was not an array."; - - return; - } - } - - public static function hideSection( $opt_name = '', $id = '', $hide = true ) { - self::check_opt_name( $opt_name ); - - if ( ! empty( $opt_name ) && ! empty( $id ) ) { - if ( isset ( self::$sections[ $opt_name ][ $id ] ) ) { - self::$sections[ $opt_name ][ $id ]['hidden'] = $hide; - } - } - } - - public static function processFieldsArray( $opt_name = "", $section_id = "", $fields = array() ) { - if ( ! empty( $opt_name ) && ! empty( $section_id ) && is_array( $fields ) && ! empty( $fields ) ) { - foreach ( $fields as $field ) { - if ( ! is_array( $field ) ) { - continue; - } - $field['section_id'] = $section_id; - self::setField( $opt_name, $field ); - } - } - } - - public static function getField( $opt_name = '', $id = '' ) { - self::check_opt_name( $opt_name ); - if ( ! empty( $opt_name ) && ! empty( $id ) ) { - return isset( self::$fields[ $opt_name ][ $id ] ) ? self::$fields[ $opt_name ][ $id ] : false; - } - - return false; - } - - public static function hideField( $opt_name = '', $id = '', $hide = true ) { - self::check_opt_name( $opt_name ); - - if ( ! empty( $opt_name ) && ! empty( $id ) ) { - if ( isset ( self::$fields[ $opt_name ][ $id ] ) ) { - if ( ! $hide ) { - self::$fields[ $opt_name ][ $id ]['class'] = str_replace( 'hidden', '', self::$fields[ $opt_name ][ $id ]['class'] ); - } else { - self::$fields[ $opt_name ][ $id ]['class'] .= 'hidden'; - } - } - } - } - - public static function setField( $opt_name = '', $field = array() ) { - self::check_opt_name( $opt_name ); - - if ( ! empty( $opt_name ) && is_array( $field ) && ! empty( $field ) ) { - - if ( ! isset( $field['priority'] ) ) { - $field['priority'] = self::getPriority( $opt_name, 'fields' ); - } - if ( isset( $field['id'] ) ) { - self::$fields[ $opt_name ][ $field['id'] ] = $field; - } - } - } - - public static function removeField( $opt_name = '', $id = '' ) { - self::check_opt_name( $opt_name ); - - if ( ! empty( $opt_name ) && ! empty( $id ) ) { - if ( isset( self::$fields[ $opt_name ][ $id ] ) ) { - foreach ( self::$fields[ $opt_name ] as $key => $field ) { - if ( $key == $id ) { - $priority = $field['priority']; - self::$priority[ $opt_name ]['fields'] --; - unset( self::$fields[ $opt_name ][ $id ] ); - continue; - } - if ( isset( $priority ) && $priority != "" ) { - $newPriority = $field['priority']; - $field['priority'] = $priority; - self::$fields[ $opt_name ][ $key ] = $field; - $priority = $newPriority; - } - } - } - } - - return false; - } - - public static function setHelpTab( $opt_name = "", $tab = array() ) { - self::check_opt_name( $opt_name ); - if ( ! empty( $opt_name ) && ! empty( $tab ) ) { - if ( ! isset( self::$args[ $opt_name ]['help_tabs'] ) ) { - self::$args[ $opt_name ]['help_tabs'] = array(); - } - if ( isset( $tab['id'] ) ) { - self::$args[ $opt_name ]['help_tabs'][] = $tab; - } else if ( is_array( end( $tab ) ) ) { - foreach ( $tab as $tab_item ) { - self::$args[ $opt_name ]['help_tabs'][] = $tab_item; - } - } - } - } - - public static function setHelpSidebar( $opt_name = "", $content = "" ) { - self::check_opt_name( $opt_name ); - if ( ! empty( $opt_name ) && ! empty( $content ) ) { - self::$args[ $opt_name ]['help_sidebar'] = $content; - } - } - - public static function setArgs( $opt_name = "", $args = array() ) { - self::check_opt_name( $opt_name ); - if ( ! empty( $opt_name ) && ! empty( $args ) && is_array( $args ) ) { - if ( isset( self::$args[ $opt_name ] ) && isset( self::$args[ $opt_name ]['clearArgs'] ) ) { - self::$args[ $opt_name ] = array(); - } - self::$args[ $opt_name ] = wp_parse_args( $args, self::$args[ $opt_name ] ); - } - } - - public static function getArgs( $opt_name = "" ) { - self::check_opt_name( $opt_name ); - if ( ! empty( $opt_name ) && ! empty( self::$args[ $opt_name ] ) ) { - return self::$args[ $opt_name ]; - } - } - - public static function getArg( $opt_name = "", $key = "" ) { - self::check_opt_name( $opt_name ); - if ( ! empty( $opt_name ) && ! empty( $key ) && ! empty( self::$args[ $opt_name ] ) ) { - return self::$args[ $opt_name ][ $key ]; - } else { - return; - } - } - - public static function getPriority( $opt_name, $type ) { - $priority = self::$priority[ $opt_name ][ $type ]; - self::$priority[ $opt_name ][ $type ] += 1; - - return $priority; - } - - public static function check_opt_name( $opt_name = "" ) { - if ( empty( $opt_name ) || is_array( $opt_name ) ) { - return; - } - if ( ! isset( self::$sections[ $opt_name ] ) ) { - self::$sections[ $opt_name ] = array(); - self::$priority[ $opt_name ]['sections'] = 1; - } - if ( ! isset( self::$args[ $opt_name ] ) ) { - self::$args[ $opt_name ] = array(); - self::$priority[ $opt_name ]['args'] = 1; - } - if ( ! isset( self::$fields[ $opt_name ] ) ) { - self::$fields[ $opt_name ] = array(); - self::$priority[ $opt_name ]['fields'] = 1; - } - if ( ! isset( self::$help[ $opt_name ] ) ) { - self::$help[ $opt_name ] = array(); - self::$priority[ $opt_name ]['help'] = 1; - } - if ( ! isset( self::$errors[ $opt_name ] ) ) { - self::$errors[ $opt_name ] = array(); - } - if ( ! isset( self::$init[ $opt_name ] ) ) { - self::$init[ $opt_name ] = false; - } - } - - /** - * Retrieve metadata from a file. Based on WP Core's get_file_data function - * - * @since 2.1.1 - * - * @param string $file Path to the file - * - * @return string - */ - public static function getFileVersion( $file ) { - $data = get_file_data( $file, array( 'version' ), 'plugin' ); - - return $data[0]; - } - - public static function checkExtensionClassFile( $opt_name, $name = "", $class_file = "", $instance = "" ) { - if ( file_exists( $class_file ) ) { - self::$uses_extensions[ $opt_name ] = isset( self::$uses_extensions[ $opt_name ] ) ? self::$uses_extensions[ $opt_name ] : array(); - if ( ! in_array( $name, self::$uses_extensions[ $opt_name ] ) ) { - self::$uses_extensions[ $opt_name ][] = $name; - } - - self::$extensions[ $name ] = isset( self::$extensions[ $name ] ) ? self::$extensions[ $name ] : array(); - $version = Redux_Helpers::get_template_version( $class_file ); - if ( empty( $version ) && ! empty( $instance ) ) { - if ( isset( $instance->version ) ) { - $version = $instance->version; - } - } - self::$extensions[ $name ][ $version ] = isset( self::$extensions[ $name ][ $version ] ) ? self::$extensions[ $name ][ $version ] : $class_file; - } - } - - public static function setExtensions( $opt_name, $path ) { - if ( is_dir( $path ) ) { - $path = trailingslashit( $path ); - $folder = str_replace( '.php', '', basename( $path ) ); - if ( file_exists( $path . 'extension_' . $folder . '.php' ) ) { - self::checkExtensionClassFile( $opt_name, $folder, $path . 'extension_' . $folder . '.php' ); - } else { - $folders = scandir( $path, 1 ); - foreach ( $folders as $folder ) { - if ( $folder === '.' or $folder === '..' ) { - continue; - } - if ( file_exists( $path . $folder . '/extension_' . $folder . '.php' ) ) { - self::checkExtensionClassFile( $opt_name, $folder, $path . $folder . '/extension_' . $folder . '.php' ); - } else if ( is_dir( $path . $folder ) ) { - self::setExtensions( $opt_name, $path . $folder ); - continue; - } - } - } - } else if ( file_exists( $path ) ) { - $name = explode( 'extension_', basename( $path ) ); - if ( isset( $name[1] ) && ! empty( $name[1] ) ) { - $name = str_replace( '.php', '', $name[1] ); - self::checkExtensionClassFile( $opt_name, $name, $path ); - } - } - } - - public static function getAllExtensions() { - $redux = ReduxFrameworkInstances::get_all_instances(); - foreach ( $redux as $instance ) { - if ( ! empty( self::$uses_extensions[ $instance['args']['opt_name'] ] ) ) { - continue; - } - if ( ! empty( $instance['extensions'] ) ) { - - Redux::getInstanceExtensions( $instance['args']['opt_name'], $instance ); - } - } - } - - public static function getInstanceExtensions( $opt_name, $instance = array() ) { - if ( ! empty( self::$uses_extensions[ $opt_name ] ) ) { - return; - } - if ( empty( $instance ) ) { - $instance = ReduxFrameworkInstances::get_instance( $opt_name ); - } - if ( empty( $instance ) || empty( $instance->extensions ) ) { - return; - } - foreach ( $instance->extensions as $name => $extension ) { - if ( $name == "widget_areas" ) { - $new = new Redux_Widget_Areas( $instance ); - } - if ( isset( self::$uses_extensions[ $opt_name ][ $name ] ) ) { - continue; - } - if ( isset( $extension->extension_dir ) ) { - Redux::setExtensions( $opt_name, str_replace( $name, '', $extension->extension_dir ) ); - - } else if ( isset( $extension->_extension_dir ) ) { - Redux::setExtensions( $opt_name, str_replace( $name, '', $extension->_extension_dir ) ); - } - } - } - - public static function getExtensions( $opt_name = "", $key = "" ) { - - if ( empty( $opt_name ) ) { - Redux::getAllExtensions(); - if ( empty( $key ) ) { - return self::$extension_paths; - } else { - if ( isset( self::$extension_paths[ $key ] ) ) { - return self::$extension_paths[ $key ]; - } - } - } else { - if ( empty( self::$uses_extensions[ $opt_name ] ) ) { - Redux::getInstanceExtensions( $opt_name ); - } - - if ( empty( self::$uses_extensions[ $opt_name ] ) ) { - return false; - } - $instanceExtensions = array(); - foreach ( self::$uses_extensions[ $opt_name ] as $extension ) { - $class_file = end( self::$extensions[ $extension ] ); - $name = str_replace( '.php', '', basename( $extension ) ); - $extension_class = 'ReduxFramework_Extension_' . $name; - $instanceExtensions[ $extension ] = array( - 'path' => $class_file, - 'class' => $extension_class, - 'version' => Redux_Helpers::get_template_version( $class_file ) - ); - } - - return $instanceExtensions; - } - - return false; - } - } - - Redux::load(); - } diff --git a/library/admin/ReduxCore/inc/class.redux_cdn.php b/library/admin/ReduxCore/inc/class.redux_cdn.php deleted file mode 100644 index 60c43e7c..00000000 --- a/library/admin/ReduxCore/inc/class.redux_cdn.php +++ /dev/null @@ -1,155 +0,0 @@ -args['dev_mode'] ) { - $msg = sprintf( __( 'If you are developing offline, please download and install the Redux Vendor Support plugin/extension to bypass the our CDN and avoid this warning', 'redux-framework' ), 'https://github.com/reduxframework/redux-vendor-support' ); - } - - self::$_parent->admin_notices[] = array( - 'type' => 'error', - 'msg' => '' . __( 'Redux Framework Warning', 'redux-framework' ) . '
    ' . sprintf( __( '%s CDN unavailable. Some controls may not render properly.', 'redux-framework' ), $handle ) . ' ' . $msg, - 'id' => $handle . $tran_key, - 'dismiss' => false, - ); - - } - } - } else { - set_transient( $handle . $tran_key, true, MINUTE_IN_SECONDS * self::$_parent->args['cdn_check_time'] ); - - if ( $register ) { - self::_register( $handle, $src_cdn, $deps, $ver, $footer_or_media, $is_script ); - } else { - self::_enqueue( $handle, $src_cdn, $deps, $ver, $footer_or_media, $is_script ); - } - } - } - } - - private static function _vendor_plugin( $register = true, $handle, $src_cdn, $deps, $ver, $footer_or_media, $is_script = true ) { - if ( class_exists( 'Redux_VendorURL' ) ) { - $src = Redux_VendorURL::get_url( $handle ); - - if ( $register ) { - self::_register( $handle, $src, $deps, $ver, $footer_or_media, $is_script ); - } else { - self::_enqueue( $handle, $src, $deps, $ver, $footer_or_media, $is_script ); - } - } else { - if ( ! self::$_set ) { - self::$_parent->admin_notices[] = array( - 'type' => 'error', - 'msg' => sprintf( __( 'The Vendor Support plugin (or extension) is either not installed or not activated and thus, some controls may not render properly. Please ensure that it is installed and activated', 'redux-framework' ), 'https://github.com/reduxframework/redux-vendor-support', admin_url( 'plugins.php' ) ), - 'id' => $handle . '23', - 'dismiss' => false, - ); - - self::$_set = true; - } - } - } - - public static function register_style( $handle, $src_cdn = false, $deps = array(), $ver = false, $media = 'all' ) { - if ( self::$_parent->args['use_cdn'] ) { - self::_cdn( true, $handle, $src_cdn, $deps, $ver, $media, $is_script = false ); - } else { - self::_vendor_plugin( true, $handle, $src_cdn, $deps, $ver, $media, $is_script = false ); - } - } - - public static function register_script( $handle, $src_cdn = false, $deps = array(), $ver = false, $in_footer = false ) { - if ( self::$_parent->args['use_cdn'] ) { - self::_cdn( true, $handle, $src_cdn, $deps, $ver, $in_footer, $is_script = true ); - } else { - self::_vendor_plugin( true, $handle, $src_cdn, $deps, $ver, $in_footer, $is_script = true ); - } - } - - public static function enqueue_style( $handle, $src_cdn = false, $deps = array(), $ver = false, $media = 'all' ) { - if ( self::$_parent->args['use_cdn'] ) { - self::_cdn( false, $handle, $src_cdn, $deps, $ver, $media, $is_script = false ); - } else { - self::_vendor_plugin( false, $handle, $src_cdn, $deps, $ver, $media, $is_script = false ); - } - } - - public static function enqueue_script( $handle, $src_cdn = false, $deps = array(), $ver = false, $in_footer = false ) { - if ( self::$_parent->args['use_cdn'] ) { - self::_cdn( false, $handle, $src_cdn, $deps, $ver, $in_footer, $is_script = true ); - } else { - self::_vendor_plugin( false, $handle, $src_cdn, $deps, $ver, $in_footer, $is_script = true ); - } - } - } - } diff --git a/library/admin/ReduxCore/inc/class.redux_filesystem.php b/library/admin/ReduxCore/inc/class.redux_filesystem.php deleted file mode 100644 index d62eeb0f..00000000 --- a/library/admin/ReduxCore/inc/class.redux_filesystem.php +++ /dev/null @@ -1,269 +0,0 @@ -parent->admin_notices[] = array( - 'type' => 'error', - 'msg' => '' . __( 'File Permission Issues', 'redux-framework' ) . '
    ' . sprintf( __( 'We were unable to modify required files. Please check your permissions, or modify your wp-config.php file to contain your FTP login credentials as outlined here.', 'redux-framework' ), 'https://codex.wordpress.org/Editing_wp-config.php#WordPress_Upgrade_Constants' ), - 'id' => 'redux-wp-login', - 'dismiss' => false, - ); - } - - /** - * Return an instance of this class. - * - * @since 1.0.0 - * @return object A single instance of this class. - */ - public static function get_instance( $parent = null ) { - - // If the single instance hasn't been set, set it now. - if ( null == self::$instance ) { - self::$instance = new self; - } - - if ( $parent !== null ) { - self::$instance->parent = $parent; - } - - return self::$instance; - } - - public function ftp_form() { - if ( isset( $this->parent->ftp_form ) && ! empty( $this->parent->ftp_form ) ) { - echo '

    '; - echo '' . __( 'File Permission Issues', 'redux-framework' ) . '
    ' . sprintf( __( 'We were unable to modify required files. Please ensure that %1s has the proper read-write permissions, or modify your wp-config.php file to contain your FTP login credentials as outlined here.', 'redux-framework' ), Redux_Helpers::cleanFilePath( trailingslashit( WP_CONTENT_DIR ) ) . '/uploads/', 'https://codex.wordpress.org/Editing_wp-config.php#WordPress_Upgrade_Constants' ); - echo '

    ' . '
    '; - } - } - - function filesystem_init( $form_url, $method = '', $context = false, $fields = null ) { - global $wp_filesystem; - - if ( ! empty( $this->creds ) ) { - return true; - } - - ob_start(); - - /* first attempt to get credentials */ - if ( false === ( $this->creds = request_filesystem_credentials( $form_url, $method, false, $context ) ) ) { - $this->creds = array(); - $this->parent->ftp_form = ob_get_contents(); - ob_end_clean(); - - /** - * if we comes here - we don't have credentials - * so the request for them is displaying - * no need for further processing - **/ - - return false; - } - - /* now we got some credentials - try to use them*/ - if ( ! WP_Filesystem( $this->creds ) ) { - $this->creds = array(); - /* incorrect connection data - ask for credentials again, now with error message */ - request_filesystem_credentials( $form_url, '', true, $context ); - $this->parent->ftp_form = ob_get_contents(); - ob_end_clean(); - - return false; - } - - return true; - } - - - public static function load_direct() { - if ( self::$direct === null ) { - require_once ABSPATH . '/wp-admin/includes/class-wp-filesystem-base.php'; - require_once ABSPATH . '/wp-admin/includes/class-wp-filesystem-direct.php'; - self::$direct = new WP_Filesystem_Direct( array() ); - } - } - - public function execute( $action, $file = '', $params = '' ) { - - if ( empty( $this->parent->args ) ) { - return; - } - - if ( ! empty ( $params ) ) { - extract( $params ); - } - - if ( ! is_dir( ReduxFramework::$_upload_dir ) ) { - wp_mkdir_p( ReduxFramework::$_upload_dir ); - } - - // Setup the filesystem with creds - require_once ABSPATH . '/wp-admin/includes/template.php'; - require_once ABSPATH . '/wp-admin/includes/file.php'; - - if ( $this->parent->args['menu_type'] == 'submenu' ) { - $page_parent = $this->parent->args['page_parent']; - $base = $page_parent . '?page=' . $this->parent->args['page_slug']; - } else { - $base = 'admin.php?page=' . $this->parent->args['page_slug']; - } - - $url = wp_nonce_url( $base, 'redux-options' ); - - $this->filesystem_init( $url, 'direct', dirname( $file ) ); - - return $this->do_action( $action, $file, $params ); - } - - public function do_action( $action, $file = '', $params = '' ) { - - if ( ! empty ( $params ) ) { - extract( $params ); - } - - global $wp_filesystem; - - if ( ! isset( $params['chmod'] ) || ( isset( $params['chmod'] ) && empty( $params['chmod'] ) ) ) { - if ( defined( 'FS_CHMOD_FILE' ) ) { - $chmod = FS_CHMOD_FILE; - } else { - $chmod = 0644; - } - } - $res = false; - if ( ! isset( $recursive ) ) { - $recursive = false; - } - - //$target_dir = $wp_filesystem->find_folder( dirname( $file ) ); - - // Do unique stuff - if ( $action == 'mkdir' ) { - - if ( defined( 'FS_CHMOD_DIR' ) ) { - $chmod = FS_CHMOD_DIR; - } else { - $chmod = 0755; - } - $res = $wp_filesystem->mkdir( $file ); - if ( ! $res ) { - wp_mkdir_p( $file ); - - $res = file_exists( $file ); - if ( ! $res ) { - mkdir( $file, $chmod, true ); - $res = file_exists( $file ); - } - } - } elseif ( $action == 'rmdir' ) { - $res = $wp_filesystem->rmdir( $file, $recursive ); - } elseif ( $action == 'copy' && ! isset( $this->filesystem->killswitch ) ) { - if ( isset( $this->parent->ftp_form ) && ! empty( $this->parent->ftp_form ) ) { - $res = copy( $file, $destination ); - if ( $res ) { - chmod( $destination, $chmod ); - } - } else { - $res = $wp_filesystem->copy( $file, $destination, $overwrite, $chmod ); - } - } elseif ( $action == 'move' && ! isset( $this->filesystem->killswitch ) ) { - $res = $wp_filesystem->copy( $file, $destination, $overwrite ); - } elseif ( $action == 'delete' ) { - $res = $wp_filesystem->delete( $file, $recursive ); - } elseif ( $action == 'rmdir' ) { - $res = $wp_filesystem->rmdir( $file, $recursive ); - } elseif ( $action == 'dirlist' ) { - if ( ! isset( $include_hidden ) ) { - $include_hidden = true; - } - $res = $wp_filesystem->dirlist( $file, $include_hidden, $recursive ); - } elseif ( $action == 'put_contents' && ! isset( $this->filesystem->killswitch ) ) { - // Write a string to a file - if ( isset( $this->parent->ftp_form ) && ! empty( $this->parent->ftp_form ) ) { - self::load_direct(); - $res = self::$direct->put_contents( $file, $content, $chmod ); - } else { - $res = $wp_filesystem->put_contents( $file, $content, $chmod ); - } - } elseif ( $action == 'chown' ) { - // Changes file owner - if ( isset( $owner ) && ! empty( $owner ) ) { - $res = $wp_filesystem->chmod( $file, $chmod, $recursive ); - } - } elseif ( $action == 'owner' ) { - // Gets file owner - $res = $wp_filesystem->owner( $file ); - } elseif ( $action == 'chmod' ) { - - if ( ! isset( $params['chmod'] ) || ( isset( $params['chmod'] ) && empty( $params['chmod'] ) ) ) { - $chmod = false; - } - - $res = $wp_filesystem->chmod( $file, $chmod, $recursive ); - - } elseif ( $action == 'get_contents' ) { - // Reads entire file into a string - if ( isset( $this->parent->ftp_form ) && ! empty( $this->parent->ftp_form ) ) { - self::load_direct(); - $res = self::$direct->get_contents( $file ); - } else { - $res = $wp_filesystem->get_contents( $file ); - } - } elseif ( $action == 'get_contents_array' ) { - // Reads entire file into an array - $res = $wp_filesystem->get_contents_array( $file ); - } elseif ( $action == 'object' ) { - $res = $wp_filesystem; - } elseif ( $action == 'unzip' ) { - $unzipfile = unzip_file( $file, $destination ); - if ( $unzipfile ) { - $res = true; - } - } - - if ( ! $res ) { - $this->killswitch = true; - $this->parent->admin_notices[] = array( - 'type' => 'error', - 'msg' => '' . __( 'File Permission Issues', 'redux-framework' ) . '
    ' . sprintf( __( 'We were unable to modify required files. Please ensure that %1s has the proper read-write permissions, or modify your wp-config.php file to contain your FTP login credentials as outlined here.', 'redux-framework' ), Redux_Helpers::cleanFilePath( trailingslashit( WP_CONTENT_DIR ) ) . '/uploads/', 'https://codex.wordpress.org/Editing_wp-config.php#WordPress_Upgrade_Constants' ), - 'id' => 'redux-wp-login', - 'dismiss' => false, - ); - //add_action( "redux/page/{$this->parent->args['opt_name']}/form/before", array( - // $this, - // 'ftp_form' - //) ); - } - - return $res; - } - } - - Redux_Filesystem::get_instance(); - } diff --git a/library/admin/ReduxCore/inc/class.redux_functions.php b/library/admin/ReduxCore/inc/class.redux_functions.php deleted file mode 100644 index 770eefe4..00000000 --- a/library/admin/ReduxCore/inc/class.redux_functions.php +++ /dev/null @@ -1,217 +0,0 @@ -args['dev_mode'] ) { - $min = '.min'; - } - - return $min; - } - - /** - * Sets a cookie. - * Do nothing if unit testing. - * - * @since 3.5.4 - * @access public - * @return void - * - * @param string $name The cookie name. - * @param string $value The cookie value. - * @param integer $expire Expiry time. - * @param string $path The cookie path. - * @param string $domain The cookie domain. - * @param boolean $secure HTTPS only. - * @param boolean $httponly Only set cookie on HTTP calls. - */ - public static function setCookie( $name, $value, $expire = 0, $path, $domain = null, $secure = false, $httponly = false ) { - if ( ! defined( 'WP_TESTS_DOMAIN' ) ) { - setcookie( $name, $value, $expire, $path, $domain, $secure, $httponly ); - } - } - - /** - * Parse CSS from output/compiler array - * - * @since 3.2.8 - * @access private - * @return $css CSS string - */ - public static function parseCSS( $cssArray = array(), $style = '', $value = '' ) { - - // Something wrong happened - if ( count( $cssArray ) == 0 ) { - return; - } else { //if ( count( $cssArray ) >= 1 ) { - $css = ''; - - foreach ( $cssArray as $element => $selector ) { - - // The old way - if ( $element === 0 ) { - $css = self::theOldWay( $cssArray, $style ); - - return $css; - } - - // New way continued - $cssStyle = $element . ':' . $value . ';'; - - $css .= $selector . '{' . $cssStyle . '}'; - } - } - - return $css; - } - - private static function theOldWay( $cssArray, $style ) { - $keys = implode( ",", $cssArray ); - $css = $keys . "{" . $style . '}'; - - return $css; - } - - /** - * initWpFilesystem - Initialized the Wordpress filesystem, if it already isn't. - * - * @since 3.2.3 - * @access public - * @return void - */ - public static function initWpFilesystem() { - global $wp_filesystem; - - // Initialize the Wordpress filesystem, no more using file_put_contents function - if ( empty( $wp_filesystem ) ) { - require_once ABSPATH . '/wp-admin/includes/file.php'; - WP_Filesystem(); - } - } - - /** - * verFromGit - Retrives latest Redux version from GIT - * - * @since 3.2.0 - * @access private - * @return string $ver - */ - private static function verFromGit() { - // Get the raw framework.php from github - $gitpage = wp_remote_get( - 'https://raw.github.com/ReduxFramework/redux-framework/master/ReduxCore/framework.php', array( - 'headers' => array( - 'Accept-Encoding' => '' - ), - 'sslverify' => true, - 'timeout' => 300 - ) ); - - // Is the response code the corect one? - if ( ! is_wp_error( $gitpage ) ) { - if ( isset( $gitpage['body'] ) ) { - // Get the page text. - $body = $gitpage['body']; - - // Find version line in framework.php - $needle = 'public static $_version ='; - $pos = strpos( $body, $needle ); - - // If it's there, continue. We don't want errors if $pos = 0. - if ( $pos > 0 ) { - - // Look for the semi-colon at the end of the version line - $semi = strpos( $body, ";", $pos ); - - // Error avoidance. If the semi-colon is there, continue. - if ( $semi > 0 ) { - - // Extract the version line - $text = substr( $body, $pos, ( $semi - $pos ) ); - - // Find the first quote around the veersion number. - $quote = strpos( $body, "'", $pos ); - - // Extract the version number - $ver = substr( $body, $quote, ( $semi - $quote ) ); - - // Strip off quotes. - $ver = str_replace( "'", '', $ver ); - - return $ver; - } - } - } - } - } - - /** - * updateCheck - Checks for updates to Redux Framework - * - * @since 3.2.0 - * @access public - * - * @param string $curVer Current version of Redux Framework - * - * @return void - Admin notice is diaplyed if new version is found - */ - public static function updateCheck( $curVer ) { - - // If no cookie, check for new ver - if ( ! isset( $_COOKIE['redux_update_check'] ) ) { // || 1 == strcmp($_COOKIE['redux_update_check'], self::$_version)) { - // actual ver number from git repo - $ver = self::verFromGit(); - - // hour long cookie. - setcookie( "redux_update_check", $ver, time() + 3600, '/' ); - } else { - - // saved value from cookie. If it's different from current ver - // we can still show the update notice. - $ver = $_COOKIE['redux_update_check']; - } - - // Set up admin notice on new version - //if ( 1 == strcmp( $ver, $curVer ) ) { - if ( version_compare( $ver, $curVer, '>' ) ) { - self::$_parent->admin_notices[] = array( - 'type' => 'updated', - 'msg' => 'A new build of Redux is now available!

    Your version: ' . $curVer . '
    New version: ' . $ver . '

    If you are not a developer, your theme/plugin author shipped with dev_mode on. Contact them to fix it, but in the meantime you can use our dev_mode disabler.

    Get it now  |', - 'id' => 'dev_notice_' . $ver, - 'dismiss' => true, - ); - } - } - - public static function tru( $string, $opt_name ) { - return apply_filters( 'redux/' . $opt_name . '/aURL_filter', '' ); - } - - } - } diff --git a/library/admin/ReduxCore/inc/class.redux_helpers.php b/library/admin/ReduxCore/inc/class.redux_helpers.php deleted file mode 100644 index 152a3579..00000000 --- a/library/admin/ReduxCore/inc/class.redux_helpers.php +++ /dev/null @@ -1,694 +0,0 @@ -sections as $k => $section ) { - if ( ! isset( $section['title'] ) ) { - continue; - } - - if ( isset( $section['fields'] ) && ! empty( $section['fields'] ) ) { - if ( Redux_Helpers::recursive_array_search( $field, $section['fields'] ) ) { - return $k; - continue; - } - } - } - } - - public static function isFieldInUseByType( $fields, $field = array() ) { - foreach ( $field as $name ) { - if ( array_key_exists( $name, $fields ) ) { - return true; - } - } - - return false; - } - - public static function isFieldInUse( $parent, $field ) { - foreach ( $parent->sections as $k => $section ) { - if ( ! isset( $section['title'] ) ) { - continue; - } - - if ( isset( $section['fields'] ) && ! empty( $section['fields'] ) ) { - if ( Redux_Helpers::recursive_array_search( $field, $section['fields'] ) ) { - return true; - continue; - } - } - } - } - - public static function major_version( $v ) { - $version = explode( '.', $v ); - if ( count( $version ) > 1 ) { - return $version[0] . '.' . $version[1]; - } else { - return $v; - } - } - - public static function isLocalHost() { - return ( $_SERVER['REMOTE_ADDR'] === '127.0.0.1' || $_SERVER['REMOTE_ADDR'] === 'localhost' ) ? 1 : 0; - } - - public static function isWpDebug() { - return ( defined( 'WP_DEBUG' ) && WP_DEBUG == true ); - } - - public static function getTrackingObject() { - global $wpdb; - - $hash = md5( network_site_url() . '-' . $_SERVER['REMOTE_ADDR'] ); - - global $blog_id, $wpdb; - $pts = array(); - - foreach ( get_post_types( array( 'public' => true ) ) as $pt ) { - $count = wp_count_posts( $pt ); - $pts[ $pt ] = $count->publish; - } - - $comments_count = wp_count_comments(); - $theme_data = wp_get_theme(); - $theme = array( - 'version' => $theme_data->Version, - 'name' => $theme_data->Name, - 'author' => $theme_data->Author, - 'template' => $theme_data->Template, - ); - - if ( ! function_exists( 'get_plugin_data' ) ) { - require_once ABSPATH . 'wp-admin/includes/admin.php'; - } - - $plugins = array(); - foreach ( get_option( 'active_plugins', array() ) as $plugin_path ) { - $plugin_info = get_plugin_data( WP_PLUGIN_DIR . '/' . $plugin_path ); - - $slug = str_replace( '/' . basename( $plugin_path ), '', $plugin_path ); - $plugins[ $slug ] = array( - 'version' => $plugin_info['Version'], - 'name' => $plugin_info['Name'], - 'plugin_uri' => $plugin_info['PluginURI'], - 'author' => $plugin_info['AuthorName'], - 'author_uri' => $plugin_info['AuthorURI'], - ); - } - if ( is_multisite() ) { - foreach ( get_option( 'active_sitewide_plugins', array() ) as $plugin_path ) { - $plugin_info = get_plugin_data( WP_PLUGIN_DIR . '/' . $plugin_path ); - $slug = str_replace( '/' . basename( $plugin_path ), '', $plugin_path ); - $plugins[ $slug ] = array( - 'version' => $plugin_info['Version'], - 'name' => $plugin_info['Name'], - 'plugin_uri' => $plugin_info['PluginURI'], - 'author' => $plugin_info['AuthorName'], - 'author_uri' => $plugin_info['AuthorURI'], - ); - } - } - - - $version = explode( '.', PHP_VERSION ); - $version = array( - 'major' => $version[0], - 'minor' => $version[0] . '.' . $version[1], - 'release' => PHP_VERSION - ); - - $user_query = new WP_User_Query( array( 'blog_id' => $blog_id, 'count_total' => true, ) ); - $comments_query = new WP_Comment_Query(); - - $data = array( - '_id' => $hash, - 'localhost' => ( $_SERVER['REMOTE_ADDR'] === '127.0.0.1' ) ? 1 : 0, - 'php' => $version, - 'site' => array( - 'hash' => $hash, - 'version' => get_bloginfo( 'version' ), - 'multisite' => is_multisite(), - 'users' => $user_query->get_total(), - 'lang' => get_locale(), - 'wp_debug' => ( defined( 'WP_DEBUG' ) ? WP_DEBUG ? true : false : false ), - 'memory' => WP_MEMORY_LIMIT, - ), - 'pts' => $pts, - 'comments' => array( - 'total' => $comments_count->total_comments, - 'approved' => $comments_count->approved, - 'spam' => $comments_count->spam, - 'pings' => $comments_query->query( array( 'count' => true, 'type' => 'pingback' ) ), - ), - 'options' => apply_filters( 'redux/tracking/options', array() ), - 'theme' => $theme, - 'redux' => array( - 'mode' => ReduxFramework::$_is_plugin ? 'plugin' : 'theme', - 'version' => ReduxFramework::$_version, - 'demo_mode' => get_option( 'ReduxFrameworkPlugin' ), - ), - 'developer' => apply_filters( 'redux/tracking/developer', array() ), - 'plugins' => $plugins, - ); - - $parts = explode( ' ', $_SERVER['SERVER_SOFTWARE'] ); - $software = array(); - foreach ( $parts as $part ) { - if ( $part[0] == "(" ) { - continue; - } - if ( strpos( $part, '/' ) !== false ) { - $chunk = explode( "/", $part ); - $software[ strtolower( $chunk[0] ) ] = $chunk[1]; - } - } - $software['full'] = $_SERVER['SERVER_SOFTWARE']; - $data['environment'] = $software; - $data['environment']['mysql'] = $wpdb->db_version(); -// if ( function_exists( 'mysqli_get_server_info' ) ) { -// $link = mysqli_connect() or die( "Error " . mysqli_error( $link ) ); -// $data['environment']['mysql'] = mysqli_get_server_info( $link ); -// } else if ( class_exists( 'PDO' ) && method_exists( 'PDO', 'getAttribute' ) ) { -// $data['environment']['mysql'] = PDO::getAttribute( PDO::ATTR_SERVER_VERSION ); -// } else { -// $data['environment']['mysql'] = mysql_get_server_info(); -// } - - if ( empty( $data['developer'] ) ) { - unset( $data['developer'] ); - } - - return $data; - } - - public static function trackingObject() { - - $data = wp_remote_post( - 'http://verify.redux.io', - array( - 'body' => array( - 'hash' => $_GET['action'], - 'site' => esc_url( home_url( '/' ) ), - ) - ) - ); - - $data['body'] = urldecode( $data['body'] ); - - if ( ! isset( $_GET['code'] ) || $data['body'] != $_GET['code'] ) { - die(); - } - - return Redux_Helpers::getTrackingObject(); - } - - public static function isParentTheme( $file ) { - $file = self::cleanFilePath( $file ); - $dir = self::cleanFilePath( get_template_directory() ); - - $file = str_replace( '//', '/', $file ); - $dir = str_replace( '//', '/', $dir ); - - if ( strpos( $file, $dir ) !== false ) { - return true; - } - - return false; - } - - public static function isChildTheme( $file ) { - $file = self::cleanFilePath( $file ); - $dir = self::cleanFilePath( get_stylesheet_directory() ); - - $file = str_replace( '//', '/', $file ); - $dir = str_replace( '//', '/', $dir ); - - if ( strpos( $file, $dir ) !== false ) { - return true; - } - - return false; - } - - private static function reduxAsPlugin() { - return ReduxFramework::$_as_plugin; - } - - public static function isTheme( $file ) { - - if ( true == self::isChildTheme( $file ) || true == self::isParentTheme( $file ) ) { - return true; - } - - return false; - } - - public static function array_in_array( $needle, $haystack ) { - //Make sure $needle is an array for foreach - if ( ! is_array( $needle ) ) { - $needle = array( $needle ); - } - //For each value in $needle, return TRUE if in $haystack - foreach ( $needle as $pin ) //echo 'needle' . $pin; - { - if ( in_array( $pin, $haystack ) ) { - return true; - } - } - - //Return FALSE if none of the values from $needle are found in $haystack - return false; - } - - public static function recursive_array_search( $needle, $haystack ) { - foreach ( $haystack as $key => $value ) { - if ( $needle === $value || ( is_array( $value ) && self::recursive_array_search( $needle, $value ) !== false ) ) { - return true; - } - } - - return false; - } - - /** - * Take a path and return it clean - * - * @param string $path - * - * @since 3.1.7 - */ - public static function cleanFilePath( $path ) { - $path = str_replace( '', '', str_replace( array( "\\", "\\\\" ), '/', $path ) ); - - if ( $path[ strlen( $path ) - 1 ] === '/' ) { - $path = rtrim( $path, '/' ); - } - - return $path; - } - - /** - * Take a path and delete it - * - * @param string $path - * - * @since 3.3.3 - */ - public static function rmdir( $dir ) { - if ( is_dir( $dir ) ) { - $objects = scandir( $dir ); - foreach ( $objects as $object ) { - if ( $object != "." && $object != ".." ) { - if ( filetype( $dir . "/" . $object ) == "dir" ) { - rrmdir( $dir . "/" . $object ); - } else { - unlink( $dir . "/" . $object ); - } - } - } - reset( $objects ); - rmdir( $dir ); - } - } - - /** - * Field Render Function. - * Takes the color hex value and converts to a rgba. - * - * @since ReduxFramework 3.0.4 - */ - public static function hex2rgba( $hex, $alpha = '' ) { - $hex = str_replace( "#", "", $hex ); - if ( strlen( $hex ) == 3 ) { - $r = hexdec( substr( $hex, 0, 1 ) . substr( $hex, 0, 1 ) ); - $g = hexdec( substr( $hex, 1, 1 ) . substr( $hex, 1, 1 ) ); - $b = hexdec( substr( $hex, 2, 1 ) . substr( $hex, 2, 1 ) ); - } else { - $r = hexdec( substr( $hex, 0, 2 ) ); - $g = hexdec( substr( $hex, 2, 2 ) ); - $b = hexdec( substr( $hex, 4, 2 ) ); - } - $rgb = $r . ',' . $g . ',' . $b; - - if ( '' == $alpha ) { - return $rgb; - } else { - $alpha = floatval( $alpha ); - - return 'rgba(' . $rgb . ',' . $alpha . ')'; - } - } - - public static function makeBoolStr( $var ) { - if ( $var == false || $var == 'false' || $var == 0 || $var == '0' || $var == '' || empty( $var ) ) { - return 'false'; - } else { - return 'true'; - } - } - - public static function compileSystemStatus( $json_output = false, $remote_checks = false ) { - global $wpdb; - - $sysinfo = array(); - - $sysinfo['home_url'] = home_url(); - $sysinfo['site_url'] = site_url(); - $sysinfo['redux_ver'] = esc_html( ReduxFramework::$_version ); - $sysinfo['redux_data_dir'] = ReduxFramework::$_upload_dir; - $f = 'fo' . 'pen'; - // Only is a file-write check - $sysinfo['redux_data_writeable'] = self::makeBoolStr( @$f( ReduxFramework::$_upload_dir . 'test-log.log', 'a' ) ); - $sysinfo['wp_content_url'] = WP_CONTENT_URL; - $sysinfo['wp_ver'] = get_bloginfo( 'version' ); - $sysinfo['wp_multisite'] = is_multisite(); - $sysinfo['permalink_structure'] = get_option( 'permalink_structure' ) ? get_option( 'permalink_structure' ) : 'Default'; - $sysinfo['front_page_display'] = get_option( 'show_on_front' ); - if ( $sysinfo['front_page_display'] == 'page' ) { - $front_page_id = get_option( 'page_on_front' ); - $blog_page_id = get_option( 'page_for_posts' ); - - $sysinfo['front_page'] = $front_page_id != 0 ? get_the_title( $front_page_id ) . ' (#' . $front_page_id . ')' : 'Unset'; - $sysinfo['posts_page'] = $blog_page_id != 0 ? get_the_title( $blog_page_id ) . ' (#' . $blog_page_id . ')' : 'Unset'; - } - - $sysinfo['wp_mem_limit']['raw'] = self::let_to_num( WP_MEMORY_LIMIT ); - $sysinfo['wp_mem_limit']['size'] = size_format( $sysinfo['wp_mem_limit']['raw'] ); - - $sysinfo['db_table_prefix'] = 'Length: ' . strlen( $wpdb->prefix ) . ' - Status: ' . ( strlen( $wpdb->prefix ) > 16 ? 'ERROR: Too long' : 'Acceptable' ); - - $sysinfo['wp_debug'] = 'false'; - if ( defined( 'WP_DEBUG' ) && WP_DEBUG ) { - $sysinfo['wp_debug'] = 'true'; - } - - $sysinfo['wp_lang'] = get_locale(); - - if ( ! class_exists( 'Browser' ) ) { - require_once ReduxFramework::$_dir . 'inc/browser.php'; - } - - $browser = new Browser(); - - $sysinfo['browser'] = array( - 'agent' => $browser->getUserAgent(), - 'browser' => $browser->getBrowser(), - 'version' => $browser->getVersion(), - 'platform' => $browser->getPlatform(), - //'mobile' => $browser->isMobile() ? 'true' : 'false', - ); - - $sysinfo['server_info'] = esc_html( $_SERVER['SERVER_SOFTWARE'] ); - $sysinfo['localhost'] = self::makeBoolStr( self::isLocalHost() ); - $sysinfo['php_ver'] = function_exists( 'phpversion' ) ? esc_html( phpversion() ) : 'phpversion() function does not exist.'; - $sysinfo['abspath'] = ABSPATH; - - if ( function_exists( 'ini_get' ) ) { - $sysinfo['php_mem_limit'] = size_format( self::let_to_num( ini_get( 'memory_limit' ) ) ); - $sysinfo['php_post_max_size'] = size_format( self::let_to_num( ini_get( 'post_max_size' ) ) ); - $sysinfo['php_time_limit'] = ini_get( 'max_execution_time' ); - $sysinfo['php_max_input_var'] = ini_get( 'max_input_vars' ); - $sysinfo['php_display_errors'] = self::makeBoolStr( ini_get( 'display_errors' ) ); - } - - $sysinfo['suhosin_installed'] = extension_loaded( 'suhosin' ); - $sysinfo['mysql_ver'] = $wpdb->db_version(); - $sysinfo['max_upload_size'] = size_format( wp_max_upload_size() ); - - $sysinfo['def_tz_is_utc'] = 'true'; - if ( date_default_timezone_get() !== 'UTC' ) { - $sysinfo['def_tz_is_utc'] = 'false'; - } - - $sysinfo['fsockopen_curl'] = 'false'; - if ( function_exists( 'fsockopen' ) || function_exists( 'curl_init' ) ) { - $sysinfo['fsockopen_curl'] = 'true'; - } - - //$sysinfo['soap_client'] = 'false'; - //if ( class_exists( 'SoapClient' ) ) { - // $sysinfo['soap_client'] = 'true'; - //} - // - //$sysinfo['dom_document'] = 'false'; - //if ( class_exists( 'DOMDocument' ) ) { - // $sysinfo['dom_document'] = 'true'; - //} - - //$sysinfo['gzip'] = 'false'; - //if ( is_callable( 'gzopen' ) ) { - // $sysinfo['gzip'] = 'true'; - //} - - if ( $remote_checks == true ) { - $response = wp_remote_post( 'https://www.paypal.com/cgi-bin/webscr', array( - 'sslverify' => false, - 'timeout' => 60, - 'user-agent' => 'ReduxFramework/' . ReduxFramework::$_version, - 'body' => array( - 'cmd' => '_notify-validate' - ) - ) ); - - if ( ! is_wp_error( $response ) && $response['response']['code'] >= 200 && $response['response']['code'] < 300 ) { - $sysinfo['wp_remote_post'] = 'true'; - $sysinfo['wp_remote_post_error'] = ''; - } else { - $sysinfo['wp_remote_post'] = 'false'; - $sysinfo['wp_remote_post_error'] = $response->get_error_message(); - } - - $response = wp_remote_get( 'http://reduxframework.com/wp-admin/admin-ajax.php?action=get_redux_extensions' ); - - if ( ! is_wp_error( $response ) && $response['response']['code'] >= 200 && $response['response']['code'] < 300 ) { - $sysinfo['wp_remote_get'] = 'true'; - $sysinfo['wp_remote_get_error'] = ''; - } else { - $sysinfo['wp_remote_get'] = 'false'; - $sysinfo['wp_remote_get_error'] = $response->get_error_message(); - } - } - - $active_plugins = (array) get_option( 'active_plugins', array() ); - - if ( is_multisite() ) { - $active_plugins = array_merge( $active_plugins, get_site_option( 'active_sitewide_plugins', array() ) ); - } - - $sysinfo['plugins'] = array(); - - foreach ( $active_plugins as $plugin ) { - $plugin_data = @get_plugin_data( WP_PLUGIN_DIR . '/' . $plugin ); - $plugin_name = esc_html( $plugin_data['Name'] ); - - $sysinfo['plugins'][ $plugin_name ] = $plugin_data; - } - - $redux = ReduxFrameworkInstances::get_all_instances(); - - $sysinfo['redux_instances'] = array(); - - if ( ! empty( $redux ) && is_array( $redux ) ) { - foreach ( $redux as $inst => $data ) { - Redux::init( $inst ); - - $sysinfo['redux_instances'][ $inst ]['args'] = $data->args; - $sysinfo['redux_instances'][ $inst ]['sections'] = $data->sections; - foreach ( $sysinfo['redux_instances'][ $inst ]['sections'] as $sKey => $section ) { - if ( isset( $section['fields'] ) && is_array( $section['fields'] ) ) { - foreach ( $section['fields'] as $fKey => $field ) { - if ( isset( $field['validate_callback'] ) ) { - unset( $sysinfo['redux_instances'][ $inst ]['sections'][ $sKey ]['fields'][ $fKey ]['validate_callback'] ); - } - if ( $field['type'] == "js_button" ) { - if ( isset( $field['script'] ) && isset( $field['script']['ver'] ) ) { - unset( $sysinfo['redux_instances'][ $inst ]['sections'][ $sKey ]['fields'][ $fKey ]['script']['ver'] ); - } - } - - } - } - } - - $sysinfo['redux_instances'][ $inst ]['extensions'] = Redux::getExtensions( $inst ); - - if ( isset( $data->extensions['metaboxes'] ) ) { - $data->extensions['metaboxes']->init(); - $sysinfo['redux_instances'][ $inst ]['metaboxes'] = $data->extensions['metaboxes']->boxes; - } - - if ( isset( $data->args['templates_path'] ) && $data->args['templates_path'] != '' ) { - $sysinfo['redux_instances'][ $inst ]['templates'] = self::getReduxTemplates( $data->args['templates_path'] ); - } - } - } - - $active_theme = wp_get_theme(); - - $sysinfo['theme']['name'] = $active_theme->Name; - $sysinfo['theme']['version'] = $active_theme->Version; - $sysinfo['theme']['author_uri'] = $active_theme->{'Author URI'}; - $sysinfo['theme']['is_child'] = self::makeBoolStr( is_child_theme() ); - - if ( is_child_theme() ) { - $parent_theme = wp_get_theme( $active_theme->Template ); - - $sysinfo['theme']['parent_name'] = $parent_theme->Name; - $sysinfo['theme']['parent_version'] = $parent_theme->Version; - $sysinfo['theme']['parent_author_uri'] = $parent_theme->{'Author URI'}; - } - - //if ( $json_output ) { - // $sysinfo = json_encode( $sysinfo ); - //} - - //print_r($sysinfo); - //exit(); - - return $sysinfo; - } - - private static function getReduxTemplates( $custom_template_path ) { - $filesystem = Redux_Filesystem::get_instance(); - $template_paths = array( 'ReduxFramework' => ReduxFramework::$_dir . 'templates/panel' ); - $scanned_files = array(); - $found_files = array(); - $outdated_templates = false; - - foreach ( $template_paths as $plugin_name => $template_path ) { - $scanned_files[ $plugin_name ] = self::scan_template_files( $template_path ); - } - - foreach ( $scanned_files as $plugin_name => $files ) { - foreach ( $files as $file ) { - if ( file_exists( $custom_template_path . '/' . $file ) ) { - $theme_file = $custom_template_path . '/' . $file; - } else { - $theme_file = false; - } - - if ( $theme_file ) { - $core_version = self::get_template_version( ReduxFramework::$_dir . 'templates/panel/' . $file ); - $theme_version = self::get_template_version( $theme_file ); - - if ( $core_version && ( empty( $theme_version ) || version_compare( $theme_version, $core_version, '<' ) ) ) { - if ( ! $outdated_templates ) { - $outdated_templates = true; - } - - $found_files[ $plugin_name ][] = sprintf( __( '%s version %s is out of date. The core version is %s', 'redux-framework' ), str_replace( WP_CONTENT_DIR . '/themes/', '', $theme_file ), $theme_version ? $theme_version : '-', $core_version ); - } else { - $found_files[ $plugin_name ][] = sprintf( '%s', str_replace( WP_CONTENT_DIR . '/themes/', '', $theme_file ) ); - } - } - } - } - - return $found_files; - } - - public static function rURL_fix( $base, $opt_name ) { - $url = $base . urlencode( 'http://ads.reduxframework.com/api/index.php?js&g&1&v=2' ) . '&proxy=' . urlencode( $base ) . ''; - - return Redux_Functions::tru( $url, $opt_name ); - } - - private static function scan_template_files( $template_path ) { - $files = scandir( $template_path ); - $result = array(); - - if ( $files ) { - foreach ( $files as $key => $value ) { - if ( ! in_array( $value, array( ".", ".." ) ) ) { - if ( is_dir( $template_path . DIRECTORY_SEPARATOR . $value ) ) { - $sub_files = redux_scan_template_files( $template_path . DIRECTORY_SEPARATOR . $value ); - foreach ( $sub_files as $sub_file ) { - $result[] = $value . DIRECTORY_SEPARATOR . $sub_file; - } - } else { - $result[] = $value; - } - } - } - } - - return $result; - } - - public static function get_template_version( $file ) { - $filesystem = Redux_Filesystem::get_instance(); - // Avoid notices if file does not exist - if ( ! file_exists( $file ) ) { - return ''; - } - // - //// We don't need to write to the file, so just open for reading. - //$fp = fopen( $file, 'r' ); - // - //// Pull only the first 8kiB of the file in. - //$file_data = fread( $fp, 8192 ); - // - //// PHP will close file handle, but we are good citizens. - //fclose( $fp ); - // - // Make sure we catch CR-only line endings. - - $data = get_file_data( $file, array( 'version' ), 'plugin' ); - if ( ! empty( $data[0] ) ) { - return $data[0]; - } else { - $file_data = $filesystem->execute( 'get_contents', $file ); - - $file_data = str_replace( "\r", "\n", $file_data ); - $version = ''; - - if ( preg_match( '/^[ \t\/*#@]*' . preg_quote( '@version', '/' ) . '(.*)$/mi', $file_data, $match ) && $match[1] ) { - $version = _cleanup_header_comment( $match[1] ); - } - - return $version; - } - } - - private static function let_to_num( $size ) { - $l = substr( $size, - 1 ); - $ret = substr( $size, 0, - 1 ); - - switch ( strtoupper( $l ) ) { - case 'P': - $ret *= 1024; - case 'T': - $ret *= 1024; - case 'G': - $ret *= 1024; - case 'M': - $ret *= 1024; - case 'K': - $ret *= 1024; - } - - return $ret; - } - - } - } - - - diff --git a/library/admin/ReduxCore/inc/class.redux_instances.php b/library/admin/ReduxCore/inc/class.redux_instances.php deleted file mode 100644 index bffcbea1..00000000 --- a/library/admin/ReduxCore/inc/class.redux_instances.php +++ /dev/null @@ -1,166 +0,0 @@ -options = get_option( 'redux-framework-tracking' ); - $this->options['dev_mode'] = false; - - if ( ! isset( $this->options['hash'] ) || ! $this->options['hash'] || empty( $this->options['hash'] ) ) { - $this->options['hash'] = md5( network_site_url() . '-' . $_SERVER['REMOTE_ADDR'] ); - update_option( 'redux-framework-tracking', $this->options ); - } - - if ( isset( $_GET['redux_framework_disable_tracking'] ) && ! empty( $_GET['redux_framework_disable_tracking'] ) ) { - $this->options['allow_tracking'] = false; - update_option( 'redux-framework-tracking', $this->options ); - } - - if ( isset( $_GET['redux_framework_enable_tracking'] ) && ! empty( $_GET['redux_framework_enable_tracking'] ) ) { - $this->options['allow_tracking'] = true; - update_option( 'redux-framework-tracking', $this->options ); - } - - header( "Expires: Mon, 26 Jul 1997 05:00:00 GMT" ); - header( "Last-Modified: " . gmdate( "D, d M Y H:i:s" ) . "GMT" ); - header( 'Expires: Sat, 26 Jul 1997 05:00:00 GMT' ); - header( 'Cache-Control: no-store, no-cache, must-revalidate' ); - header( 'Cache-Control: post-check=0, pre-check=0', false ); - header( 'Pragma: no-cache' ); - $instances = ReduxFrameworkInstances::get_all_instances(); - - if ( isset( $_REQUEST['i'] ) && ! empty( $_REQUEST['i'] ) ) { - if ( is_array( $instances ) && ! empty( $instances ) ) { - foreach ( $instances as $opt_name => $data ) { - if ( md5( $opt_name . '-debug' ) == $_REQUEST['i'] ) { - $array = $instances[ $opt_name ]; - } - if ($data->args['dev_mode']) { - $this->options['dev_mode'] = $data->args['dev_mode']; - } - } - } - if ( isset( $array ) ) { - if ( isset( $array->extensions ) && is_array( $array->extensions ) && ! empty( $array->extensions ) ) { - foreach ( $array->extensions as $key => $extension ) { - if ( isset( $extension->$version ) ) { - $array->extensions[ $key ] = $extension->$version; - } else { - $array->extensions[ $key ] = true; - } - } - } - - if ( isset( $array->import_export ) ) { - unset( $array->import_export ); - } - - if ( isset( $array->debug ) ) { - unset( $array->debug ); - } - } else { - die(); - } - - } else { - $array = Redux_Helpers::trackingObject(); - if ( is_array( $instances ) && ! empty( $instances ) ) { - $array['instances'] = array(); - foreach ( $instances as $opt_name => $data ) { - $array['instances'][] = $opt_name; - } - } - $array['key'] = md5( AUTH_KEY . SECURE_AUTH_KEY ); - } - - echo @json_encode( $array, true ); - die(); - } - - function capture( $ReduxFramework ) { - $this->store( $ReduxFramework ); - } - - private function store( $ReduxFramework ) { - if ( $ReduxFramework instanceof ReduxFramework ) { - $key = $ReduxFramework->args['opt_name']; - self::$instances[ $key ] = $ReduxFramework; - } - } - } diff --git a/library/admin/ReduxCore/inc/extensions/README.txt b/library/admin/ReduxCore/inc/extensions/README.txt deleted file mode 100644 index ea1d54cf..00000000 --- a/library/admin/ReduxCore/inc/extensions/README.txt +++ /dev/null @@ -1 +0,0 @@ -This directory is a placeholder for Redux Framework extensions. diff --git a/library/admin/ReduxCore/inc/extensions/customizer/extension_customizer.css b/library/admin/ReduxCore/inc/extensions/customizer/extension_customizer.css deleted file mode 100644 index f76d28ab..00000000 --- a/library/admin/ReduxCore/inc/extensions/customizer/extension_customizer.css +++ /dev/null @@ -1 +0,0 @@ -.redux-section p.customize-section-description{margin-top:22px;word-break:break-word}.redux-section p.customize-section-description.legacy{margin-top:7px}.control-section-themes .accordion-section-title{margin:0}#customize-controls .customize-info{margin-bottom:0}#customize-controls .redux-section .accordion-section-content{background:#FCFCFC}.redux-section .accordion-section-title i,.redux-field .accordion-field-title i,.redux-panel .accordion-section-title i{margin-right:5px}.accordion-section.redux-main{background:inherit;margin-left:inherit;border-left:inherit;-moz-box-shadow:inherit;-webkit-box-shadow:inherit;padding:inherit;box-shadow:inherit}.redux_field_th{padding:13px 0px 0px 0px}.redux-main .redux-field-container{padding:10px 0}.redux-main .select_wrapper{float:none;width:100%;display:inline-block}.redux-main .select2-container{margin-right:0 !important;margin-bottom:5px !important;width:100% !important}.redux-main .select_wrapper:nth-child(odd){margin-right:0}.redux-main .redux-option-image{max-width:42% !important;margin-right:3%}.redux-main .customize-control{border-bottom:1px solid #ddd;padding-bottom:4px}.redux-main .customize-control:last-child{border-bottom:0;padding-bottom:0}.redux-main .upload{width:100% !important}.redux-main h3{margin-top:inherit}.redux-main .redux-container-raw{margin-top:22px;word-break:break-word;padding:0 !important}.redux-main .redux-container-password input{width:100%}.select2-drop{z-index:999999}.rAdsContainer{line-height:0;border:0}.rAds{position:inherit !important;right:0 !important;top:0 !important;bottom:0 !important;left:0 !important;text-align:center;margin-bottom:0;line-height:0;-webkit-transition:left ease-in-out .18s;transition:left ease-in-out .18s}.rAds img{-webkit-transition:left ease-in-out .18s;transition:left ease-in-out .18s}.admin-color-fresh #customize-theme-controls .control-section.control-section-redux:hover>h3.accordion-section-title,.admin-color-fresh #customize-theme-controls .control-section.control-section-redux h3.accordion-section-title:hover,.admin-color-fresh #customize-theme-controls .control-section.control-section-redux.open h3.accordion-section-title,.admin-color-fresh #customize-theme-controls .control-section.control-section-redux h3.accordion-section-title:focus,.admin-color-fresh #customize-theme-controls .control-panel.control-panel-redux:hover>h3.accordion-section-title,.admin-color-fresh #customize-theme-controls .control-panel.control-panel-redux h3.accordion-section-title:hover,.admin-color-fresh #customize-theme-controls .control-panel.control-panel-redux.open h3.accordion-section-title,.admin-color-fresh #customize-theme-controls .control-panel.control-panel-redux h3.accordion-section-title:focus{color:#fff;background:#0073aa}.admin-color-fresh #customize-theme-controls .control-section.control-section-redux:hover>h3.accordion-section-title:after,.admin-color-fresh #customize-theme-controls .control-section.control-section-redux h3.accordion-section-title:hover:after,.admin-color-fresh #customize-theme-controls .control-section.control-section-redux.open h3.accordion-section-title:after,.admin-color-fresh #customize-theme-controls .control-section.control-section-redux h3.accordion-section-title:focus:after,.admin-color-fresh #customize-theme-controls .control-panel.control-panel-redux:hover>h3.accordion-section-title:after,.admin-color-fresh #customize-theme-controls .control-panel.control-panel-redux h3.accordion-section-title:hover:after,.admin-color-fresh #customize-theme-controls .control-panel.control-panel-redux.open h3.accordion-section-title:after,.admin-color-fresh #customize-theme-controls .control-panel.control-panel-redux h3.accordion-section-title:focus:after{color:#fff}.admin-color-fresh #customize-theme-controls .control-section.control-panel.control-panel-redux>.accordion-section-title:after{background:transparent;border-left:none}.admin-color-fresh #customize-theme-controls .control-panel-redux .customize-panel-back:hover,.admin-color-fresh #customize-theme-controls .redux-section .customize-section-back:hover{background:#0073aa;color:#fff}.admin-color-ectoplasm #customize-theme-controls .control-section.control-section-redux:hover>h3.accordion-section-title,.admin-color-ectoplasm #customize-theme-controls .control-section.control-section-redux h3.accordion-section-title:hover,.admin-color-ectoplasm #customize-theme-controls .control-section.control-section-redux.open h3.accordion-section-title,.admin-color-ectoplasm #customize-theme-controls .control-section.control-section-redux h3.accordion-section-title:focus,.admin-color-ectoplasm #customize-theme-controls .control-panel.control-panel-redux:hover>h3.accordion-section-title,.admin-color-ectoplasm #customize-theme-controls .control-panel.control-panel-redux h3.accordion-section-title:hover,.admin-color-ectoplasm #customize-theme-controls .control-panel.control-panel-redux.open h3.accordion-section-title,.admin-color-ectoplasm #customize-theme-controls .control-panel.control-panel-redux h3.accordion-section-title:focus{color:#fff;background:#a3b745}.admin-color-ectoplasm #customize-theme-controls .control-section.control-section-redux:hover>h3.accordion-section-title:after,.admin-color-ectoplasm #customize-theme-controls .control-section.control-section-redux h3.accordion-section-title:hover:after,.admin-color-ectoplasm #customize-theme-controls .control-section.control-section-redux.open h3.accordion-section-title:after,.admin-color-ectoplasm #customize-theme-controls .control-section.control-section-redux h3.accordion-section-title:focus:after,.admin-color-ectoplasm #customize-theme-controls .control-panel.control-panel-redux:hover>h3.accordion-section-title:after,.admin-color-ectoplasm #customize-theme-controls .control-panel.control-panel-redux h3.accordion-section-title:hover:after,.admin-color-ectoplasm #customize-theme-controls .control-panel.control-panel-redux.open h3.accordion-section-title:after,.admin-color-ectoplasm #customize-theme-controls .control-panel.control-panel-redux h3.accordion-section-title:focus:after{color:#fff}.admin-color-ectoplasm #customize-theme-controls .control-section.control-panel.control-panel-redux>.accordion-section-title:after{background:transparent;border-left:none}.admin-color-ectoplasm #customize-theme-controls .control-panel-redux .customize-panel-back:hover,.admin-color-ectoplasm #customize-theme-controls .redux-section .customize-section-back:hover{background:#a3b745;color:#fff}.admin-color-light #customize-theme-controls .control-section.control-section-redux:hover>h3.accordion-section-title,.admin-color-light #customize-theme-controls .control-section.control-section-redux h3.accordion-section-title:hover,.admin-color-light #customize-theme-controls .control-section.control-section-redux.open h3.accordion-section-title,.admin-color-light #customize-theme-controls .control-section.control-section-redux h3.accordion-section-title:focus,.admin-color-light #customize-theme-controls .control-panel.control-panel-redux:hover>h3.accordion-section-title,.admin-color-light #customize-theme-controls .control-panel.control-panel-redux h3.accordion-section-title:hover,.admin-color-light #customize-theme-controls .control-panel.control-panel-redux.open h3.accordion-section-title,.admin-color-light #customize-theme-controls .control-panel.control-panel-redux h3.accordion-section-title:focus{color:#fff;background:#888}.admin-color-light #customize-theme-controls .control-section.control-section-redux:hover>h3.accordion-section-title:after,.admin-color-light #customize-theme-controls .control-section.control-section-redux h3.accordion-section-title:hover:after,.admin-color-light #customize-theme-controls .control-section.control-section-redux.open h3.accordion-section-title:after,.admin-color-light #customize-theme-controls .control-section.control-section-redux h3.accordion-section-title:focus:after,.admin-color-light #customize-theme-controls .control-panel.control-panel-redux:hover>h3.accordion-section-title:after,.admin-color-light #customize-theme-controls .control-panel.control-panel-redux h3.accordion-section-title:hover:after,.admin-color-light #customize-theme-controls .control-panel.control-panel-redux.open h3.accordion-section-title:after,.admin-color-light #customize-theme-controls .control-panel.control-panel-redux h3.accordion-section-title:focus:after{color:#fff}.admin-color-light #customize-theme-controls .control-section.control-panel.control-panel-redux>.accordion-section-title:after{background:transparent;border-left:none}.admin-color-light #customize-theme-controls .control-panel-redux .customize-panel-back:hover,.admin-color-light #customize-theme-controls .redux-section .customize-section-back:hover{background:#888;color:#fff}.admin-color-blue #customize-theme-controls .control-section.control-section-redux:hover>h3.accordion-section-title,.admin-color-blue #customize-theme-controls .control-section.control-section-redux h3.accordion-section-title:hover,.admin-color-blue #customize-theme-controls .control-section.control-section-redux.open h3.accordion-section-title,.admin-color-blue #customize-theme-controls .control-section.control-section-redux h3.accordion-section-title:focus,.admin-color-blue #customize-theme-controls .control-panel.control-panel-redux:hover>h3.accordion-section-title,.admin-color-blue #customize-theme-controls .control-panel.control-panel-redux h3.accordion-section-title:hover,.admin-color-blue #customize-theme-controls .control-panel.control-panel-redux.open h3.accordion-section-title,.admin-color-blue #customize-theme-controls .control-panel.control-panel-redux h3.accordion-section-title:focus{color:#fff;background:#096484}.admin-color-blue #customize-theme-controls .control-section.control-section-redux:hover>h3.accordion-section-title:after,.admin-color-blue #customize-theme-controls .control-section.control-section-redux h3.accordion-section-title:hover:after,.admin-color-blue #customize-theme-controls .control-section.control-section-redux.open h3.accordion-section-title:after,.admin-color-blue #customize-theme-controls .control-section.control-section-redux h3.accordion-section-title:focus:after,.admin-color-blue #customize-theme-controls .control-panel.control-panel-redux:hover>h3.accordion-section-title:after,.admin-color-blue #customize-theme-controls .control-panel.control-panel-redux h3.accordion-section-title:hover:after,.admin-color-blue #customize-theme-controls .control-panel.control-panel-redux.open h3.accordion-section-title:after,.admin-color-blue #customize-theme-controls .control-panel.control-panel-redux h3.accordion-section-title:focus:after{color:#fff}.admin-color-blue #customize-theme-controls .control-section.control-panel.control-panel-redux>.accordion-section-title:after{background:transparent;border-left:none}.admin-color-blue #customize-theme-controls .control-panel-redux .customize-panel-back:hover,.admin-color-blue #customize-theme-controls .redux-section .customize-section-back:hover{background:#096484;color:#fff}.admin-color-coffee #customize-theme-controls .control-section.control-section-redux:hover>h3.accordion-section-title,.admin-color-coffee #customize-theme-controls .control-section.control-section-redux h3.accordion-section-title:hover,.admin-color-coffee #customize-theme-controls .control-section.control-section-redux.open h3.accordion-section-title,.admin-color-coffee #customize-theme-controls .control-section.control-section-redux h3.accordion-section-title:focus,.admin-color-coffee #customize-theme-controls .control-panel.control-panel-redux:hover>h3.accordion-section-title,.admin-color-coffee #customize-theme-controls .control-panel.control-panel-redux h3.accordion-section-title:hover,.admin-color-coffee #customize-theme-controls .control-panel.control-panel-redux.open h3.accordion-section-title,.admin-color-coffee #customize-theme-controls .control-panel.control-panel-redux h3.accordion-section-title:focus{color:#fff;background:#c7a589}.admin-color-coffee #customize-theme-controls .control-section.control-section-redux:hover>h3.accordion-section-title:after,.admin-color-coffee #customize-theme-controls .control-section.control-section-redux h3.accordion-section-title:hover:after,.admin-color-coffee #customize-theme-controls .control-section.control-section-redux.open h3.accordion-section-title:after,.admin-color-coffee #customize-theme-controls .control-section.control-section-redux h3.accordion-section-title:focus:after,.admin-color-coffee #customize-theme-controls .control-panel.control-panel-redux:hover>h3.accordion-section-title:after,.admin-color-coffee #customize-theme-controls .control-panel.control-panel-redux h3.accordion-section-title:hover:after,.admin-color-coffee #customize-theme-controls .control-panel.control-panel-redux.open h3.accordion-section-title:after,.admin-color-coffee #customize-theme-controls .control-panel.control-panel-redux h3.accordion-section-title:focus:after{color:#fff}.admin-color-coffee #customize-theme-controls .control-section.control-panel.control-panel-redux>.accordion-section-title:after{background:transparent;border-left:none}.admin-color-coffee #customize-theme-controls .control-panel-redux .customize-panel-back:hover,.admin-color-coffee #customize-theme-controls .redux-section .customize-section-back:hover{background:#c7a589;color:#fff}.admin-color-ectoplasm #customize-theme-controls .control-section.control-section-redux:hover>h3.accordion-section-title,.admin-color-ectoplasm #customize-theme-controls .control-section.control-section-redux h3.accordion-section-title:hover,.admin-color-ectoplasm #customize-theme-controls .control-section.control-section-redux.open h3.accordion-section-title,.admin-color-ectoplasm #customize-theme-controls .control-section.control-section-redux h3.accordion-section-title:focus,.admin-color-ectoplasm #customize-theme-controls .control-panel.control-panel-redux:hover>h3.accordion-section-title,.admin-color-ectoplasm #customize-theme-controls .control-panel.control-panel-redux h3.accordion-section-title:hover,.admin-color-ectoplasm #customize-theme-controls .control-panel.control-panel-redux.open h3.accordion-section-title,.admin-color-ectoplasm #customize-theme-controls .control-panel.control-panel-redux h3.accordion-section-title:focus{color:#fff;background:#523f6d}.admin-color-ectoplasm #customize-theme-controls .control-section.control-section-redux:hover>h3.accordion-section-title:after,.admin-color-ectoplasm #customize-theme-controls .control-section.control-section-redux h3.accordion-section-title:hover:after,.admin-color-ectoplasm #customize-theme-controls .control-section.control-section-redux.open h3.accordion-section-title:after,.admin-color-ectoplasm #customize-theme-controls .control-section.control-section-redux h3.accordion-section-title:focus:after,.admin-color-ectoplasm #customize-theme-controls .control-panel.control-panel-redux:hover>h3.accordion-section-title:after,.admin-color-ectoplasm #customize-theme-controls .control-panel.control-panel-redux h3.accordion-section-title:hover:after,.admin-color-ectoplasm #customize-theme-controls .control-panel.control-panel-redux.open h3.accordion-section-title:after,.admin-color-ectoplasm #customize-theme-controls .control-panel.control-panel-redux h3.accordion-section-title:focus:after{color:#fff}.admin-color-ectoplasm #customize-theme-controls .control-section.control-panel.control-panel-redux>.accordion-section-title:after{background:transparent;border-left:none}.admin-color-ectoplasm #customize-theme-controls .control-panel-redux .customize-panel-back:hover,.admin-color-ectoplasm #customize-theme-controls .redux-section .customize-section-back:hover{background:#523f6d;color:#fff}.admin-color-midnight #customize-theme-controls .control-section.control-section-redux:hover>h3.accordion-section-title,.admin-color-midnight #customize-theme-controls .control-section.control-section-redux h3.accordion-section-title:hover,.admin-color-midnight #customize-theme-controls .control-section.control-section-redux.open h3.accordion-section-title,.admin-color-midnight #customize-theme-controls .control-section.control-section-redux h3.accordion-section-title:focus,.admin-color-midnight #customize-theme-controls .control-panel.control-panel-redux:hover>h3.accordion-section-title,.admin-color-midnight #customize-theme-controls .control-panel.control-panel-redux h3.accordion-section-title:hover,.admin-color-midnight #customize-theme-controls .control-panel.control-panel-redux.open h3.accordion-section-title,.admin-color-midnight #customize-theme-controls .control-panel.control-panel-redux h3.accordion-section-title:focus{color:#fff;background:#e14d43}.admin-color-midnight #customize-theme-controls .control-section.control-section-redux:hover>h3.accordion-section-title:after,.admin-color-midnight #customize-theme-controls .control-section.control-section-redux h3.accordion-section-title:hover:after,.admin-color-midnight #customize-theme-controls .control-section.control-section-redux.open h3.accordion-section-title:after,.admin-color-midnight #customize-theme-controls .control-section.control-section-redux h3.accordion-section-title:focus:after,.admin-color-midnight #customize-theme-controls .control-panel.control-panel-redux:hover>h3.accordion-section-title:after,.admin-color-midnight #customize-theme-controls .control-panel.control-panel-redux h3.accordion-section-title:hover:after,.admin-color-midnight #customize-theme-controls .control-panel.control-panel-redux.open h3.accordion-section-title:after,.admin-color-midnight #customize-theme-controls .control-panel.control-panel-redux h3.accordion-section-title:focus:after{color:#fff}.admin-color-midnight #customize-theme-controls .control-section.control-panel.control-panel-redux>.accordion-section-title:after{background:transparent;border-left:none}.admin-color-midnight #customize-theme-controls .control-panel-redux .customize-panel-back:hover,.admin-color-midnight #customize-theme-controls .redux-section .customize-section-back:hover{background:#e14d43;color:#fff}.admin-color-ocean #customize-theme-controls .control-section.control-section-redux:hover>h3.accordion-section-title,.admin-color-ocean #customize-theme-controls .control-section.control-section-redux h3.accordion-section-title:hover,.admin-color-ocean #customize-theme-controls .control-section.control-section-redux.open h3.accordion-section-title,.admin-color-ocean #customize-theme-controls .control-section.control-section-redux h3.accordion-section-title:focus,.admin-color-ocean #customize-theme-controls .control-panel.control-panel-redux:hover>h3.accordion-section-title,.admin-color-ocean #customize-theme-controls .control-panel.control-panel-redux h3.accordion-section-title:hover,.admin-color-ocean #customize-theme-controls .control-panel.control-panel-redux.open h3.accordion-section-title,.admin-color-ocean #customize-theme-controls .control-panel.control-panel-redux h3.accordion-section-title:focus{color:#fff;background:#9ebaa0}.admin-color-ocean #customize-theme-controls .control-section.control-section-redux:hover>h3.accordion-section-title:after,.admin-color-ocean #customize-theme-controls .control-section.control-section-redux h3.accordion-section-title:hover:after,.admin-color-ocean #customize-theme-controls .control-section.control-section-redux.open h3.accordion-section-title:after,.admin-color-ocean #customize-theme-controls .control-section.control-section-redux h3.accordion-section-title:focus:after,.admin-color-ocean #customize-theme-controls .control-panel.control-panel-redux:hover>h3.accordion-section-title:after,.admin-color-ocean #customize-theme-controls .control-panel.control-panel-redux h3.accordion-section-title:hover:after,.admin-color-ocean #customize-theme-controls .control-panel.control-panel-redux.open h3.accordion-section-title:after,.admin-color-ocean #customize-theme-controls .control-panel.control-panel-redux h3.accordion-section-title:focus:after{color:#fff}.admin-color-ocean #customize-theme-controls .control-section.control-panel.control-panel-redux>.accordion-section-title:after{background:transparent;border-left:none}.admin-color-ocean #customize-theme-controls .control-panel-redux .customize-panel-back:hover,.admin-color-ocean #customize-theme-controls .redux-section .customize-section-back:hover{background:#9ebaa0;color:#fff}.admin-color-sunrise #customize-theme-controls .control-section.control-section-redux:hover>h3.accordion-section-title,.admin-color-sunrise #customize-theme-controls .control-section.control-section-redux h3.accordion-section-title:hover,.admin-color-sunrise #customize-theme-controls .control-section.control-section-redux.open h3.accordion-section-title,.admin-color-sunrise #customize-theme-controls .control-section.control-section-redux h3.accordion-section-title:focus,.admin-color-sunrise #customize-theme-controls .control-panel.control-panel-redux:hover>h3.accordion-section-title,.admin-color-sunrise #customize-theme-controls .control-panel.control-panel-redux h3.accordion-section-title:hover,.admin-color-sunrise #customize-theme-controls .control-panel.control-panel-redux.open h3.accordion-section-title,.admin-color-sunrise #customize-theme-controls .control-panel.control-panel-redux h3.accordion-section-title:focus{color:#fff;background:#cf4944}.admin-color-sunrise #customize-theme-controls .control-section.control-section-redux:hover>h3.accordion-section-title:after,.admin-color-sunrise #customize-theme-controls .control-section.control-section-redux h3.accordion-section-title:hover:after,.admin-color-sunrise #customize-theme-controls .control-section.control-section-redux.open h3.accordion-section-title:after,.admin-color-sunrise #customize-theme-controls .control-section.control-section-redux h3.accordion-section-title:focus:after,.admin-color-sunrise #customize-theme-controls .control-panel.control-panel-redux:hover>h3.accordion-section-title:after,.admin-color-sunrise #customize-theme-controls .control-panel.control-panel-redux h3.accordion-section-title:hover:after,.admin-color-sunrise #customize-theme-controls .control-panel.control-panel-redux.open h3.accordion-section-title:after,.admin-color-sunrise #customize-theme-controls .control-panel.control-panel-redux h3.accordion-section-title:focus:after{color:#fff}.admin-color-sunrise #customize-theme-controls .control-section.control-panel.control-panel-redux>.accordion-section-title:after{background:transparent;border-left:none}.admin-color-sunrise #customize-theme-controls .control-panel-redux .customize-panel-back:hover,.admin-color-sunrise #customize-theme-controls .redux-section .customize-section-back:hover{background:#cf4944;color:#fff} diff --git a/library/admin/ReduxCore/inc/extensions/customizer/extension_customizer.js b/library/admin/ReduxCore/inc/extensions/customizer/extension_customizer.js deleted file mode 100644 index 80871d36..00000000 --- a/library/admin/ReduxCore/inc/extensions/customizer/extension_customizer.js +++ /dev/null @@ -1,361 +0,0 @@ -/* global redux, setting */ - -/*! - SerializeJSON jQuery plugin. - https://github.com/marioizquierdo/jquery.serializeJSON - version 2.6.0 (Apr, 2015) - - Copyright (c) 2012, 2015 Mario Izquierdo - Dual licensed under the MIT (http://www.opensource.org/licenses/mit-license.php) - and GPL (http://www.opensource.org/licenses/gpl-license.php) licenses. - */ -(function( $ ) { - "use strict"; - - // jQuery('form').serializeJSON() - $.fn.serializeJSON = function( options ) { - var serializedObject, formAsArray, keys, type, value, _ref, f, opts; - f = $.serializeJSON; - opts = f.setupOpts( options ); // calculate values for options {parseNumbers, parseBoolens, parseNulls} - formAsArray = this.serializeArray(); // array of objects {name, value} - f.readCheckboxUncheckedValues( formAsArray, this, opts ); // add {name, value} of unchecked checkboxes if needed - - serializedObject = {}; - $.each( - formAsArray, function( i, input ) { - keys = f.splitInputNameIntoKeysArray( input.name, opts ); - type = keys.pop(); // the last element is always the type ("string" by default) - if ( type !== 'skip' ) { // easy way to skip a value - value = f.parseValue( input.value, type, opts ); // string, number, boolean or null - if ( opts.parseWithFunction && type === '_' ) value = opts.parseWithFunction( value, input.name ); // allow for custom parsing - f.deepSet( serializedObject, keys, value, opts ); - } - } - ); - return serializedObject; - }; - - // Use $.serializeJSON as namespace for the auxiliar functions - // and to define defaults - $.serializeJSON = { - - defaultOptions: { - checkboxUncheckedValue: undefined, // to include that value for unchecked checkboxes (instead of ignoring them) - - parseNumbers: false, // convert values like "1", "-2.33" to 1, -2.33 - parseBooleans: false, // convert "true", "false" to true, false - parseNulls: false, // convert "null" to null - parseAll: false, // all of the above - parseWithFunction: null, // to use custom parser, a function like: function(val){ return parsed_val; } - - customTypes: {}, // override defaultTypes - defaultTypes: { - string: function( str ) { - return String( str ) - }, - number: function( str ) { - return Number( str ) - }, - boolean: function( str ) { - return (["false", "null", "undefined", "", "0"].indexOf( str ) === -1) - }, - null: function( str ) { - return (["false", "null", "undefined", "", "0"].indexOf( str ) !== -1) ? null : str - }, - array: function( str ) { - return JSON.parse( str ) - }, - object: function( str ) { - return JSON.parse( str ) - }, - auto: function( str ) { - return $.serializeJSON.parseValue( - str, null, {parseNumbers: true, parseBooleans: true, parseNulls: true} - ) - } // try again with something like "parseAll" - }, - - useIntKeysAsArrayIndex: false, // name="foo[2]" value="v" => {foo: [null, null, "v"]}, instead of {foo: ["2": "v"]} - }, - - // Merge option defaults into the options - setupOpts: function( options ) { - var opt, validOpts, defaultOptions, optWithDefault, parseAll, f; - f = $.serializeJSON; - - if ( options == null ) options = {}; // options ||= {} - defaultOptions = f.defaultOptions || {}; // defaultOptions - - // Make sure that the user didn't misspell an option - validOpts = ['checkboxUncheckedValue', 'parseNumbers', 'parseBooleans', 'parseNulls', 'parseAll', 'parseWithFunction', 'customTypes', 'defaultTypes', 'useIntKeysAsArrayIndex']; // re-define because the user may override the defaultOptions - for ( opt in options ) { - if ( validOpts.indexOf( opt ) === -1 ) { - throw new Error( "serializeJSON ERROR: invalid option '" + opt + "'. Please use one of " + validOpts.join( ', ' ) ); - } - } - - // Helper to get the default value for this option if none is specified by the user - optWithDefault = function( key ) { - return (options[key] !== false) && (options[key] !== '') && (options[key] || defaultOptions[key]); - } - - // Return computed options (opts to be used in the rest of the script) - parseAll = optWithDefault( 'parseAll' ); - return { - checkboxUncheckedValue: optWithDefault( 'checkboxUncheckedValue' ), - - parseNumbers: parseAll || optWithDefault( 'parseNumbers' ), - parseBooleans: parseAll || optWithDefault( 'parseBooleans' ), - parseNulls: parseAll || optWithDefault( 'parseNulls' ), - parseWithFunction: optWithDefault( 'parseWithFunction' ), - - typeFunctions: $.extend( {}, optWithDefault( 'defaultTypes' ), optWithDefault( 'customTypes' ) ), - - useIntKeysAsArrayIndex: optWithDefault( 'useIntKeysAsArrayIndex' ), - } - }, - - // Given a string, apply the type or the relevant "parse" options, to return the parsed value - parseValue: function( str, type, opts ) { - var typeFunction, f; - f = $.serializeJSON; - - // Parse with a type if available - typeFunction = opts.typeFunctions && opts.typeFunctions[type]; - if ( typeFunction ) return typeFunction( str ); // use specific type - - // Otherwise, check if there is any auto-parse option enabled and use it. - if ( opts.parseNumbers && f.isNumeric( str ) ) return Number( str ); // auto: number - if ( opts.parseBooleans && (str === "true" || str === "false") ) return str === "true"; // auto: boolean - if ( opts.parseNulls && str == "null" ) return null; // auto: null - - // If none applies, just return the str - return str; - }, - - isObject: function( obj ) { - return obj === Object( obj ); - }, // is this variable an object? - isUndefined: function( obj ) { - return obj === void 0; - }, // safe check for undefined values - isValidArrayIndex: function( val ) { - return /^[0-9]+$/.test( String( val ) ); - }, // 1,2,3,4 ... are valid array indexes - isNumeric: function( obj ) { - return obj - parseFloat( obj ) >= 0; - }, // taken from jQuery.isNumeric implementation. Not using jQuery.isNumeric to support old jQuery and Zepto versions - - optionKeys: function( obj ) { - if ( Object.keys ) { - return Object.keys( obj ); - } else { - var keys = []; - for ( var key in obj ) { - keys.push( key ) - } - ; - return keys; - } - }, // polyfill Object.keys to get option keys in IE<9 - - // Split the input name in programatically readable keys. - // The last element is always the type (default "_"). - // Examples: - // "foo" => ['foo', '_'] - // "foo:string" => ['foo', 'string'] - // "foo:boolean" => ['foo', 'boolean'] - // "[foo]" => ['foo', '_'] - // "foo[inn][bar]" => ['foo', 'inn', 'bar', '_'] - // "foo[inn[bar]]" => ['foo', 'inn', 'bar', '_'] - // "foo[inn][arr][0]" => ['foo', 'inn', 'arr', '0', '_'] - // "arr[][val]" => ['arr', '', 'val', '_'] - // "arr[][val]:null" => ['arr', '', 'val', 'null'] - splitInputNameIntoKeysArray: function( name, opts ) { - var keys, nameWithoutType, type, _ref, f; - f = $.serializeJSON; - _ref = f.extractTypeFromInputName( name, opts ), nameWithoutType = _ref[0], type = _ref[1]; - keys = nameWithoutType.split( '[' ); // split string into array - keys = $.map( - keys, function( key ) { - return key.replace( /]/g, '' ); - } - ); // remove closing brackets - if ( keys[0] === '' ) { - keys.shift(); - } // ensure no opening bracket ("[foo][inn]" should be same as "foo[inn]") - keys.push( type ); // add type at the end - return keys; - }, - - // Returns [name-without-type, type] from name. - // "foo" => ["foo", '_'] - // "foo:boolean" => ["foo", 'boolean'] - // "foo[bar]:null" => ["foo[bar]", 'null'] - extractTypeFromInputName: function( name, opts ) { - var match, validTypes, f; - if ( match = name.match( /(.*):([^:]+)$/ ) ) { - f = $.serializeJSON; - - validTypes = f.optionKeys( opts ? opts.typeFunctions : f.defaultOptions.defaultTypes ); - validTypes.push( 'skip' ); // skip is a special type that makes it easy to remove - if ( validTypes.indexOf( match[2] ) !== -1 ) { - return [match[1], match[2]]; - } else { - throw new Error( "serializeJSON ERROR: Invalid type " + match[2] + " found in input name '" + name + "', please use one of " + validTypes.join( ', ' ) ) - } - } else { - return [name, '_']; // no defined type, then use parse options - } - }, - - // Set a value in an object or array, using multiple keys to set in a nested object or array: - // - // deepSet(obj, ['foo'], v) // obj['foo'] = v - // deepSet(obj, ['foo', 'inn'], v) // obj['foo']['inn'] = v // Create the inner obj['foo'] object, if needed - // deepSet(obj, ['foo', 'inn', '123'], v) // obj['foo']['arr']['123'] = v // - // - // deepSet(obj, ['0'], v) // obj['0'] = v - // deepSet(arr, ['0'], v, {useIntKeysAsArrayIndex: true}) // arr[0] = v - // deepSet(arr, [''], v) // arr.push(v) - // deepSet(obj, ['arr', ''], v) // obj['arr'].push(v) - // - // arr = []; - // deepSet(arr, ['', v] // arr => [v] - // deepSet(arr, ['', 'foo'], v) // arr => [v, {foo: v}] - // deepSet(arr, ['', 'bar'], v) // arr => [v, {foo: v, bar: v}] - // deepSet(arr, ['', 'bar'], v) // arr => [v, {foo: v, bar: v}, {bar: v}] - // - deepSet: function( o, keys, value, opts ) { - var key, nextKey, tail, lastIdx, lastVal, f; - if ( opts == null ) opts = {}; - f = $.serializeJSON; - if ( f.isUndefined( o ) ) { - throw new Error( "ArgumentError: param 'o' expected to be an object or array, found undefined" ); - } - if ( !keys || keys.length === 0 ) { - throw new Error( "ArgumentError: param 'keys' expected to be an array with least one element" ); - } - - key = keys[0]; - - // Only one key, then it's not a deepSet, just assign the value. - if ( keys.length === 1 ) { - if ( key === '' ) { - o.push( value ); // '' is used to push values into the array (assume o is an array) - } else { - o[key] = value; // other keys can be used as object keys or array indexes - } - - // With more keys is a deepSet. Apply recursively. - } else { - nextKey = keys[1]; - - // '' is used to push values into the array, - // with nextKey, set the value into the same object, in object[nextKey]. - // Covers the case of ['', 'foo'] and ['', 'var'] to push the object {foo, var}, and the case of nested arrays. - if ( key === '' ) { - lastIdx = o.length - 1; // asume o is array - lastVal = o[lastIdx]; - if ( f.isObject( lastVal ) && (f.isUndefined( lastVal[nextKey] ) || keys.length > 2) ) { // if nextKey is not present in the last object element, or there are more keys to deep set - key = lastIdx; // then set the new value in the same object element - } else { - key = lastIdx + 1; // otherwise, point to set the next index in the array - } - } - - // '' is used to push values into the array "array[]" - if ( nextKey === '' ) { - if ( f.isUndefined( o[key] ) || !$.isArray( o[key] ) ) { - o[key] = []; // define (or override) as array to push values - } - } else { - if ( opts.useIntKeysAsArrayIndex && f.isValidArrayIndex( nextKey ) ) { // if 1, 2, 3 ... then use an array, where nextKey is the index - if ( f.isUndefined( o[key] ) || !$.isArray( o[key] ) ) { - o[key] = []; // define (or override) as array, to insert values using int keys as array indexes - } - } else { // for anything else, use an object, where nextKey is going to be the attribute name - if ( f.isUndefined( o[key] ) || !f.isObject( o[key] ) ) { - o[key] = {}; // define (or override) as object, to set nested properties - } - } - } - - // Recursively set the inner object - tail = keys.slice( 1 ); - f.deepSet( o[key], tail, value, opts ); - } - }, - - // Fill the formAsArray object with values for the unchecked checkbox inputs, - // using the same format as the jquery.serializeArray function. - // The value of the unchecked values is determined from the opts.checkboxUncheckedValue - // and/or the data-unchecked-value attribute of the inputs. - readCheckboxUncheckedValues: function( formAsArray, $form, opts ) { - var selector, $uncheckedCheckboxes, $el, dataUncheckedValue, f; - if ( opts == null ) opts = {}; - f = $.serializeJSON; - - selector = 'input[type=checkbox][name]:not(:checked):not([disabled])'; - $uncheckedCheckboxes = $form.find( selector ).add( $form.filter( selector ) ); - $uncheckedCheckboxes.each( - function( i, el ) { - $el = $( el ); - dataUncheckedValue = $el.attr( 'data-unchecked-value' ); - if ( dataUncheckedValue ) { // data-unchecked-value has precedence over option opts.checkboxUncheckedValue - formAsArray.push( {name: el.name, value: dataUncheckedValue} ); - } else { - if ( !f.isUndefined( opts.checkboxUncheckedValue ) ) { - formAsArray.push( {name: el.name, value: opts.checkboxUncheckedValue} ); - } - } - } - ); - } - - }; - -}( window.jQuery || window.$ )); - - -(function( $ ) { //This functions first parameter is named $ - 'use strict'; - - redux.customizer = redux.customizer || {}; - - $( document ).ready( - function() { - redux.customizer.init(); - } - ); - redux.customizer.init = function() { - $( 'body' ).addClass( redux_customizer.body_class ); - $( '.accordion-section.redux-section, .accordion-section.redux-panel, .accordion-section-title' ).click( - function() { - $.redux.initFields(); - } - ); - }; - redux.customizer.save = function( $obj, $container ) { - var $parent = $obj.hasClass( 'redux-field' ) ? $obj : $obj.parents( '.redux-field:first' ); - var $id = $parent.parent().find( '.redux-customizer-input' ).data( 'id' ); - - var $nData = $parent.serializeJSON(); - - $.each( - $nData, function( $k, $v ) { - $nData = $v; - } - ); - //console.log( $nData ); - - var $control = wp.customize.control( $id ); - //console.log($control); - $control.setting.set( $nData ); - }; -})( jQuery ); - - - - - diff --git a/library/admin/ReduxCore/inc/extensions/customizer/extension_customizer.min.js b/library/admin/ReduxCore/inc/extensions/customizer/extension_customizer.min.js deleted file mode 100644 index bbbc2a87..00000000 --- a/library/admin/ReduxCore/inc/extensions/customizer/extension_customizer.min.js +++ /dev/null @@ -1 +0,0 @@ -!function(a){"use strict";a.fn.serializeJSON=function(b){var c,d,e,f,g,h,i;return h=a.serializeJSON,i=h.setupOpts(b),d=this.serializeArray(),h.readCheckboxUncheckedValues(d,this,i),c={},a.each(d,function(a,b){e=h.splitInputNameIntoKeysArray(b.name,i),f=e.pop(),"skip"!==f&&(g=h.parseValue(b.value,f,i),i.parseWithFunction&&"_"===f&&(g=i.parseWithFunction(g,b.name)),h.deepSet(c,e,g,i))}),c},a.serializeJSON={defaultOptions:{checkboxUncheckedValue:void 0,parseNumbers:!1,parseBooleans:!1,parseNulls:!1,parseAll:!1,parseWithFunction:null,customTypes:{},defaultTypes:{string:function(a){return String(a)},number:function(a){return Number(a)},"boolean":function(a){return-1===["false","null","undefined","","0"].indexOf(a)},"null":function(a){return-1!==["false","null","undefined","","0"].indexOf(a)?null:a},array:function(a){return JSON.parse(a)},object:function(a){return JSON.parse(a)},auto:function(b){return a.serializeJSON.parseValue(b,null,{parseNumbers:!0,parseBooleans:!0,parseNulls:!0})}},useIntKeysAsArrayIndex:!1},setupOpts:function(b){var c,d,e,f,g,h;h=a.serializeJSON,null==b&&(b={}),e=h.defaultOptions||{},d=["checkboxUncheckedValue","parseNumbers","parseBooleans","parseNulls","parseAll","parseWithFunction","customTypes","defaultTypes","useIntKeysAsArrayIndex"];for(c in b)if(-1===d.indexOf(c))throw new Error("serializeJSON ERROR: invalid option '"+c+"'. Please use one of "+d.join(", "));return f=function(a){return b[a]!==!1&&""!==b[a]&&(b[a]||e[a])},g=f("parseAll"),{checkboxUncheckedValue:f("checkboxUncheckedValue"),parseNumbers:g||f("parseNumbers"),parseBooleans:g||f("parseBooleans"),parseNulls:g||f("parseNulls"),parseWithFunction:f("parseWithFunction"),typeFunctions:a.extend({},f("defaultTypes"),f("customTypes")),useIntKeysAsArrayIndex:f("useIntKeysAsArrayIndex")}},parseValue:function(b,c,d){var e,f;return f=a.serializeJSON,e=d.typeFunctions&&d.typeFunctions[c],e?e(b):d.parseNumbers&&f.isNumeric(b)?Number(b):!d.parseBooleans||"true"!==b&&"false"!==b?d.parseNulls&&"null"==b?null:b:"true"===b},isObject:function(a){return a===Object(a)},isUndefined:function(a){return void 0===a},isValidArrayIndex:function(a){return/^[0-9]+$/.test(String(a))},isNumeric:function(a){return a-parseFloat(a)>=0},optionKeys:function(a){if(Object.keys)return Object.keys(a);var b=[];for(var c in a)b.push(c);return b},splitInputNameIntoKeysArray:function(b,c){var d,e,f,g,h;return h=a.serializeJSON,g=h.extractTypeFromInputName(b,c),e=g[0],f=g[1],d=e.split("["),d=a.map(d,function(a){return a.replace(/]/g,"")}),""===d[0]&&d.shift(),d.push(f),d},extractTypeFromInputName:function(b,c){var d,e,f;if(d=b.match(/(.*):([^:]+)$/)){if(f=a.serializeJSON,e=f.optionKeys(c?c.typeFunctions:f.defaultOptions.defaultTypes),e.push("skip"),-1!==e.indexOf(d[2]))return[d[1],d[2]];throw new Error("serializeJSON ERROR: Invalid type "+d[2]+" found in input name '"+b+"', please use one of "+e.join(", "))}return[b,"_"]},deepSet:function(b,c,d,e){var f,g,h,i,j,k;if(null==e&&(e={}),k=a.serializeJSON,k.isUndefined(b))throw new Error("ArgumentError: param 'o' expected to be an object or array, found undefined");if(!c||0===c.length)throw new Error("ArgumentError: param 'keys' expected to be an array with least one element");f=c[0],1===c.length?""===f?b.push(d):b[f]=d:(g=c[1],""===f&&(i=b.length-1,j=b[i],f=k.isObject(j)&&(k.isUndefined(j[g])||c.length>2)?i:i+1),""===g?(k.isUndefined(b[f])||!a.isArray(b[f]))&&(b[f]=[]):e.useIntKeysAsArrayIndex&&k.isValidArrayIndex(g)?(k.isUndefined(b[f])||!a.isArray(b[f]))&&(b[f]=[]):(k.isUndefined(b[f])||!k.isObject(b[f]))&&(b[f]={}),h=c.slice(1),k.deepSet(b[f],h,d,e))},readCheckboxUncheckedValues:function(b,c,d){var e,f,g,h,i;null==d&&(d={}),i=a.serializeJSON,e="input[type=checkbox][name]:not(:checked):not([disabled])",f=c.find(e).add(c.filter(e)),f.each(function(c,e){g=a(e),h=g.attr("data-unchecked-value"),h?b.push({name:e.name,value:h}):i.isUndefined(d.checkboxUncheckedValue)||b.push({name:e.name,value:d.checkboxUncheckedValue})})}}}(window.jQuery||window.$),function(a){"use strict";redux.customizer=redux.customizer||{},a(document).ready(function(){redux.customizer.init()}),redux.customizer.init=function(){a("body").addClass(redux_customizer.body_class),a(".accordion-section.redux-section, .accordion-section.redux-panel, .accordion-section-title").click(function(){a.redux.initFields()})},redux.customizer.save=function(b,c){var d=b.hasClass("redux-field")?b:b.parents(".redux-field:first"),e=d.parent().find(".redux-customizer-input").data("id"),f=d.serializeJSON();a.each(f,function(a,b){f=b});var g=wp.customize.control(e);g.setting.set(f)}}(jQuery); \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/extensions/customizer/extension_customizer.php b/library/admin/ReduxCore/inc/extensions/customizer/extension_customizer.php deleted file mode 100644 index 12c234a3..00000000 --- a/library/admin/ReduxCore/inc/extensions/customizer/extension_customizer.php +++ /dev/null @@ -1,807 +0,0 @@ - -//return; - /** - * Redux Framework is free software: you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation, either version 2 of the License, or - * any later version. - * Redux Framework is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - * GNU General Public License for more details. - * You should have received a copy of the GNU General Public License - * along with Redux Framework. If not, see . - * - * @package ReduxFramework - * @author Dovy Paukstys (dovy) - * @version 0.1.0 - */ - -// Exit if accessed directly - if ( ! defined( 'ABSPATH' ) ) { - exit; - } - -// Don't duplicate me! - if ( ! class_exists( 'ReduxFramework_extension_customizer' ) ) { - - /** - * Main ReduxFramework customizer extension class - * - * @since 1.0.0 - */ - class ReduxFramework_extension_customizer { - - // Protected vars - protected $redux; - private $_extension_url; - private $_extension_dir; - private $parent; - private $orig_options = array(); - private static $post_values = array(); - public static $version = "2.0.0"; - private $options = array(); - - /** - * Class Constructor. Defines the args for the extions class - * - * @since 1.0.0 - * @access public - * - * @param array $sections Panel sections. - * @param array $args Class constructor arguments. - * @param array $extra_tabs Extra panel tabs. - * - * @return void - */ - public function __construct( $parent ) { - - $this->parent = $parent; - - $this->upload_dir = ReduxFramework::$_upload_dir . 'advanced-customizer/'; - $this->upload_url = ReduxFramework::$_upload_url . 'advanced-customizer/'; - - //add_action('wp_head', array( $this, '_enqueue_new' )); - - - // Override the ReduxCore class - add_filter( "redux/extension/{$this->parent->args['opt_name']}/customizer", array( - $this, - 'remove_core_customizer_class' - ) ); - - global $pagenow, $wp_customize; - if ( ! isset( $wp_customize ) && $pagenow !== "customize.php" && $pagenow !== "admin-ajax.php" ) { - return; - } - if ( ( $pagenow !== "customize.php" && $pagenow !== "admin-ajax.php" && ! isset( $GLOBALS['wp_customize'] ) ) ) { - //return; - } - - - if ( empty( $this->_extension_dir ) ) { - $this->_extension_dir = trailingslashit( str_replace( '\\', '/', dirname( __FILE__ ) ) ); - $this->_extension_url = site_url( str_replace( trailingslashit( str_replace( '\\', '/', ABSPATH ) ), '', $this->_extension_dir ) ); - } - - self::get_post_values(); - - // Create defaults array - $defaults = array(); - /* - customize_controls_init - customize_controls_enqueue_scripts - customize_controls_print_styles - customize_controls_print_scripts - customize_controls_print_footer_scripts - */ - - //add_action('customize_save', ); - - if ( isset( $_POST['wp_customize'] ) && $_POST['wp_customize'] == "on" ) { - $this->parent->args['customizer_only'] = true; - } - - if ( isset( $_POST['wp_customize'] ) && $_POST['wp_customize'] == "on" && isset( $_POST['customized'] ) && ! empty( $_POST['customized'] ) && ! isset( $_POST['action'] ) ) { - add_action( "redux/options/{$this->parent->args['opt_name']}/options", array( - $this, - '_override_values' - ), 100 ); - } - - add_action( 'customize_register', array( - $this, - '_register_customizer_controls' - ) ); // Create controls - - add_action( 'wp_head', array( $this, 'customize_preview_init' ) ); - - - //add_action( 'customize_save', array( $this, 'customizer_save_before' ) ); // Before save - add_action( 'customize_save_after', array( &$this, 'customizer_save_after' ) ); // After save - - // Add global controls CSS file - add_action( 'customize_controls_print_scripts', array( $this, 'enqueue_controls_css' ) ); - - add_action( 'customize_controls_init', array( $this, 'enqueue_panel_css' ) ); - - - //add_action( 'wp_enqueue_scripts', array( &$this, '_enqueue_previewer_css' ) ); // Enqueue previewer css - //add_action( 'wp_enqueue_scripts', array( &$this, '_enqueue_previewer_js' ) ); // Enqueue previewer javascript - //add_action( "wp_footer", array( $this, '_enqueue_new' ), 100 ); - //$this->_enqueue_new(); - - - } - - function enqueue_controls_css() { - - include_once( ReduxFramework::$_dir . 'core/enqueue.php' ); - $enqueue = new reduxCoreEnqueue ( $this->parent ); - $enqueue->get_warnings_and_errors_array(); - $enqueue->init(); - wp_enqueue_style( 'redux-extension-advanced-customizer', $this->_extension_url . 'extension_customizer.css', '', time() ); - - wp_enqueue_script( - 'redux-extension-customizer', - $this->_extension_url . 'extension_customizer' . Redux_Functions::isMin() . '.js', - array( 'jquery', 'redux-js' ), - ReduxFramework_extension_customizer::$version, - true - ); - wp_localize_script( 'redux-extension-customizer', 'redux_customizer', array( 'body_class' => sanitize_html_class( 'admin-color-' . get_user_option( 'admin_color' ), 'fresh' ) ) ); - } - - function enqueue_panel_css() { - - } - - function remove_core_customizer_class( $path ) { - return ""; - } - - function customize_preview_init() { - do_action( 'redux/customizer/live_preview' ); - } - - protected static function get_post_values() { - if ( empty( self::$post_values ) && isset( $_POST['customized'] ) && ! empty( $_POST['customized'] ) ) { - self::$post_values = json_decode( stripslashes_deep( $_POST['customized'] ), true ); - } - } - - public function _override_values( $data ) { - - self::get_post_values(); - - - if ( isset( $_POST['customized'] ) && ! empty( self::$post_values ) ) { - - if ( is_array( self::$post_values ) ) { - foreach ( self::$post_values as $key => $value ) { - if ( strpos( $key, $this->parent->args['opt_name'] ) !== false ) { - - //if (is_array($value)) { - // $value = @stripslashes( $value ); - // if ( function_exists( 'get_magic_quotes_gpc' ) && get_magic_quotes_gpc() ) { - // $value = @array_map( 'stripslashes_deep', $value ); - // $value = @array_map( 'urldecode', $value ); - // } - //} else { - // $value = @urldecode($value); - //} - $key = str_replace( $this->parent->args['opt_name'] . '[', '', rtrim( $key, "]" ) ); - $data[ $key ] = $value; - $GLOBALS[ $this->parent->args['global_variable'] ][ $key ] = $value; - $this->parent->options[ $key ] = $value; - } - } - } - - } - - return $data; - } - - public function _enqueue_new() { - //echo ""; - //echo ""; - //echo ""; - //echo ""; - //echo ""; - //echo ""; - //echo ""; - //echo ""; - //echo ""; - //echo ""; - //echo ""; - //echo ""; - - /* - wp_enqueue_script('redux-extension-customizer-codemirror-js', $this->_extension_url . 'new/codemirror.min.js'); - wp_enqueue_script('redux-extension-customizer-color-js', $this->_extension_url . 'new/colors-control.js'); - wp_enqueue_script('redux-extension-customizer-controls-js', $this->_extension_url . 'new/customizer-control.js'); - wp_enqueue_script('redux-extension-customizer-fonts-js', $this->_extension_url . 'new/fonts-customizer-admin.js'); - wp_enqueue_script('redux-extension-customizer-header-js', $this->_extension_url . 'new/header-control.js'); - wp_enqueue_script('redux-extension-customizer-models-js', $this->_extension_url . 'new/header-models.js'); - wp_enqueue_script('redux-extension-customizer-slimscroll-js', $this->_extension_url . 'new/jquery.slimscroll.js'); - wp_enqueue_script('redux-extension-customizer-droppable-js', $this->_extension_url . 'new/jquery.ui.droppable.min.js'); - wp_enqueue_script('redux-extension-customizer-editor-js', $this->_extension_url . 'new/media-editor.min.js'); - wp_enqueue_script('redux-extension-customizer-new-js', $this->_extension_url . 'new/new-customizer.js'); - wp_enqueue_script('redux-extension-customizer-previewing-js', $this->_extension_url . 'new/previewing.js'); - wp_enqueue_script('redux-extension-customizer-theme-js', $this->_extension_url . 'new/theme-customizer.js'); - */ - } - - public function render( $control ) { - $fieldID = str_replace( $this->parent->args['opt_name'] . '-', '', $control->redux_id ); - $field = $this->options[ $fieldID ]; - - if ( isset( $field['compiler'] ) && ! empty( $field['compiler'] ) ) { - echo ''; - } else { - echo ''; - } - echo '' . $this->parent->field_head[ $field['id'] ] . ''; - echo ''; - //$field['data-customize-setting-link'] = array( - // 'name' => $field['name'], - // 'suffix' => isset($field['name_suffix']) ? $field['name_suffix'] : '' - //); - // - $field['name'] = $field['id']; - $this->parent->_field_input( $field ); - echo ''; - echo ''; - } - - // All sections, settings, and controls will be added here - public function _register_customizer_controls( $wp_customize ) { - - if ( ! class_exists( 'Redux_Customizer_Section' ) ) { - include_once dirname( __FILE__ ) . '/inc/customizer_section.php'; - if ( method_exists( $wp_customize, 'register_section_type' ) ) { - $wp_customize->register_section_type( 'Redux_Customizer_Section' ); - } - } - if ( ! class_exists( 'Redux_Customizer_Panel' ) ) { - include_once dirname( __FILE__ ) . '/inc/customizer_panel.php'; - if ( method_exists( $wp_customize, 'register_panel_type' ) ) { - $wp_customize->register_panel_type( 'Redux_Customizer_Panel' ); - } - } - if ( ! class_exists( 'Redux_Customizer_Control' ) ) { - include_once dirname( __FILE__ ) . '/inc/customizer_control.php'; - } - - include_once dirname( __FILE__ ) . '/inc/customizer_fields.php'; - include_once dirname( __FILE__ ) . '/inc/customizer_devs.php'; - - do_action( "redux/extension/customizer/control/includes" ); - - //if ($this->parent->args['dev_mode']) { - // $section = new Redux_Customizer_rAds( $wp_customize, 'redux_rAds', array( - // 'priority' => 0, - // ) ); - // $wp_customize->add_section( $section, array( - // 'priority' => 0, - // ) ); - // - // //$wp_customize->add_control( new Redux_Customizer_Control_rAds( $wp_customize, 'reduxAdsDisplay', array( - // // 'section' => 'redux_rAds', - // // 'settings' => 'redux_rAds_field', - // // 'type' => 'redux-rAds', - // //) ) ); - // - // - // - // - //} - if ( $this->parent->args['dev_mode'] ) { - //$args = array( - // 'priority' => 0, - //); - ////$section = new Redux_Customizer_Section( $wp_customize, 'redux_rAds', $args ); - ////$wp_customize->add_section( $section, $args ); - //$this->add_section( 'redux_rAds', array( - // 'title' => '', - // 'priority' => 1, - // 'description' => '', - // 'capability' => 'edit_theme_options', - //), $wp_customize ); - // - //$wp_customize->add_control( new WP_Customize_Color_Control( - // $wp_customize, - // 'redux_rAds_display', - // array( - // 'section' => 'redux_rAds', - // 'settings' => 'redux_rAds_display', - // ) - //)); - ////$wp_customize->add_control( new Redux_Customizer_Control_rAds( $wp_customize, 'reduxAdsDisplay', array( - //// 'section' => 'redux_rAds', - //// 'settings' => 'redux_rAds_field', - //// 'type' => 'redux-rAds', - ////) ) ); - //start copyright settings - - //$section = new Redux_Customizer_section_rAds( $wp_customize, 'redux_rAds', array( - // 'priority' => -999, - //) ); - //$wp_customize->add_section( $section, array( - // 'priority' => -999, - //) ); - //$wp_customize->add_setting( - // 'redux_rAds_empty' - //); - //$wp_customize->add_control( - // new Redux_Customizer_Control_rAds( - // $wp_customize, - // 'redux_rAds_empty', - // array( - // 'section' => 'redux_rAds', - // 'settings' => 'redux_rAds_empty' - // ) - // ) - //); - } - - - $order = array( - 'heading' => - 500, - 'option' => - 500, - ); - $defaults = array( - 'default-color' => '', - 'default-image' => '', - 'wp-head-callback' => '', - 'admin-head-callback' => '', - 'admin-preview-callback' => '' - ); - $panel = ""; - - $this->parent->args['options_api'] = false; - $this->parent->_register_settings(); - - foreach ( $this->parent->sections as $key => $section ) { - - // Not a type that should go on the customizer - if ( isset( $section['type'] ) && ( $section['type'] == "divide" ) ) { - continue; - } - - if ( isset( $section['id'] ) && $section['id'] == "import/export" ) { - continue; - } - - // If section customizer is set to false - if ( isset( $section['customizer'] ) && $section['customizer'] === false ) { - continue; - } - - $section['permissions'] = isset( $section['permissions'] ) ? $section['permissions'] : 'edit_theme_options'; - - // No errors please - if ( ! isset( $section['desc'] ) ) { - $section['desc'] = ""; - } - - // Fill the description if there is a subtitle - if ( empty( $section['desc'] ) && ! empty( $section['subtitle'] ) ) { - $section['desc'] = $section['subtitle']; - } - - // Let's make a section ID from the title - if ( empty( $section['id'] ) ) { - $section['id'] = strtolower( str_replace( " ", "", $section['title'] ) ); - } - - // No title is present, let's show what section is missing a title - if ( ! isset( $section['title'] ) ) { - $section['title'] = ""; - } - - // Let's set a default priority - if ( empty( $section['priority'] ) ) { - $section['priority'] = $order['heading']; - $order['heading'] ++; - } - - //print_r($section); - //print_r($this->parent->sections[$key+1]); - //echo $key; - //exit(); - - - if ( method_exists( $wp_customize, 'add_panel' ) && ( ! isset( $section['subsection'] ) || ( isset( $section['subsection'] ) && $section['subsection'] != true ) ) && isset( $this->parent->sections[ ( $key + 1 ) ]['subsection'] ) && $this->parent->sections[ ( $key + 1 ) ]['subsection'] ) { - - $this->add_panel( $section['id'], array( - 'priority' => $section['priority'], - 'capability' => $section['permissions'], - //'theme_supports' => '', - 'title' => $section['title'], - 'section' => $section, - 'opt_name' => $this->parent->args['opt_name'], - 'description' => '', - ), $wp_customize ); - $panel = $section['id']; - - $this->add_section( $section['id'], array( - 'title' => $section['title'], - 'priority' => $section['priority'], - 'description' => $section['desc'], - 'section' => $section, - 'opt_name' => $this->parent->args['opt_name'], - 'capability' => $section['permissions'], - 'panel' => $panel - ), $wp_customize ); - - - } else { - if ( ! isset( $section['subsection'] ) || ( isset( $section['subsection'] ) && $section['subsection'] != true ) ) { - $panel = ""; - } - $this->add_section( $section['id'], array( - 'title' => $section['title'], - 'priority' => $section['priority'], - 'description' => $section['desc'], - 'opt_name' => $this->parent->args['opt_name'], - 'section' => $section, - 'capability' => $section['permissions'], - 'panel' => $panel - ), $wp_customize ); - } - - if ( ! isset( $section['fields'] ) || ( isset( $section['fields'] ) && empty( $section['fields'] ) ) ) { - continue; - } - - foreach ( $section['fields'] as $skey => $option ) { - - if ( isset( $option['customizer'] ) && $option['customizer'] === false ) { - continue; - } - - if ( $this->parent->args['customizer'] === false && ( ! isset( $option['customizer'] ) || $option['customizer'] !== true ) ) { - continue; - } - - $this->options[ $option['id'] ] = $option; - add_action( 'redux/advanced_customizer/control/render/' . $this->parent->args['opt_name'] . '-' . $option['id'], array( - $this, - 'render' - ) ); - - $option['permissions'] = isset( $option['permissions'] ) ? $option['permissions'] : 'edit_theme_options'; - - // - //if ( isset( $option['validate_callback'] ) && ! empty( $option['validate_callback'] ) ) { - // continue; - //} - - - //Change the item priority if not set - if ( $option['type'] != 'heading' && ! isset( $option['priority'] ) ) { - $option['priority'] = $order['option']; - $order['option'] ++; - } - - if ( ! empty( $this->options_defaults[ $option['id'] ] ) ) { - $option['default'] = $this->options_defaults['option']['id']; - } - - //$option['id'] = $this->parent->args['opt_name'].'['.$option['id'].']'; - //echo $option['id']; - - if ( ! isset( $option['default'] ) ) { - $option['default'] = ""; - } - if ( ! isset( $option['title'] ) ) { - $option['title'] = ""; - } - - - $option['id'] = $this->parent->args['opt_name'] . '[' . $option['id'] . ']'; - - if ( $option['type'] != "heading" && $option['type'] != "import_export" && ! empty( $option['type'] ) ) { - - $wp_customize->add_setting( $option['id'], - array( - 'default' => $option['default'], - //'type' => 'option', - //'capabilities' => $option['permissions'], - //'capabilities' => 'edit_theme_options', - //'capabilities' => $this->parent->args['page_permissions'], - 'transport' => 'refresh', - 'opt_name' => $this->parent->args['opt_name'], - //'theme_supports' => '', - //'sanitize_callback' => '__return_false', - 'sanitize_callback' => array( $this, '_field_validation' ), - //'sanitize_js_callback' =>array( &$parent, '_field_input' ), - ) - ); - - } - - if ( ! empty( $option['data'] ) && empty( $option['options'] ) ) { - if ( empty( $option['args'] ) ) { - $option['args'] = array(); - } - - if ( $option['data'] == "elusive-icons" || $option['data'] == "elusive-icon" || $option['data'] == "elusive" ) { - $icons_file = ReduxFramework::$_dir . 'inc/fields/select/elusive-icons.php'; - $icons_file = apply_filters( 'redux-font-icons-file', $icons_file ); - - if ( file_exists( $icons_file ) ) { - require_once $icons_file; - } - } - $option['options'] = $this->parent->get_wordpress_data( $option['data'], $option['args'] ); - } - - $class_name = 'Redux_Customizer_Control_' . $option['type']; - - do_action( 'redux/extension/customizer/control_init', $option ); - - if ( ! class_exists( $class_name ) ) { - continue; - } - - $wp_customize->add_control( new $class_name( $wp_customize, $option['id'], array( - 'label' => $option['title'], - 'section' => $section['id'], - 'settings' => $option['id'], - 'type' => 'redux-' . $option['type'], - 'field' => $option, - 'ReduxFramework' => $this->parent, - 'priority' => $option['priority'], - ) ) ); - - $section['fields'][ $skey ]['name'] = $option['id']; - if ( ! isset ( $section['fields'][ $skey ]['class'] ) ) { // No errors please - $section['fields'][ $skey ]['class'] = ""; - } - - $this->controls[ $section['fields'][ $skey ]['id'] ] = $section['fields'][ $skey ]; - - add_action( 'redux/advanced_customizer/render/' . $option['id'], array( - $this, - 'field_render' - ), $option['priority'] ); - - - } - } - - } - - public function add_section( $id, $args = array(), $wp_customize ) { - - if ( is_a( $id, 'WP_Customize_Section' ) ) { - $section = $id; - } else { - - $section_class = apply_filters( 'redux/customizer/section/class_name', "Redux_Customizer_Section" ); - $section = new $section_class( $wp_customize, $id, $args ); - } - - $wp_customize->add_section( $section, $args ); - - } - - /** - * Add a customize panel. - * - * @since 4.0.0 - * @access public - * - * @param WP_Customize_Panel|string $id Customize Panel object, or Panel ID. - * @param array $args Optional. Panel arguments. Default empty array. - */ - public function add_panel( $id, $args = array(), $wp_customize ) { - if ( is_a( $id, 'WP_Customize_Panel' ) ) { - $panel = $id; - } else { - $panel_class = apply_filters( 'redux/customizer/panel/class_name', "Redux_Customizer_Panel" ); - $panel = new $panel_class( $wp_customize, $id, $args ); - } - - $wp_customize->add_panel( $panel, $args ); - } - - public function field_render( $option ) { - echo '1'; - preg_match_all( "/\[([^\]]*)\]/", $option->id, $matches ); - $id = $matches[1][0]; - echo $option->link(); - //$link = $option->link(); - //echo $link; - - $this->parent->_field_input( $this->controls[ $id ] ); - echo '2'; - } - - public function customizer_save_before( $plugin_options ) { - $this->before_save = $this->parent->options; - //$parent->_field_input( $plugin_options ); - } - - public function customizer_save_after( $wp_customize ) { - - if ( empty( $this->parent->options ) ) { - $this->parent->get_options(); - } - if ( empty( $this->orig_options ) && ! empty( $this->parent->options ) ) { - $this->orig_options = $this->parent->options; - } - - $options = json_decode( stripslashes_deep( $_POST['customized'] ), true ); - $compiler = false; - $changed = false; - - foreach ( $options as $key => $value ) { - if ( strpos( $key, $this->parent->args['opt_name'] ) !== false ) { - $key = str_replace( $this->parent->args['opt_name'] . '[', '', rtrim( $key, "]" ) ); - - if ( ! isset( $this->orig_options[ $key ] ) || $this->orig_options[ $key ] != $value || ( isset( $this->orig_options[ $key ] ) && ! empty( $this->orig_options[ $key ] ) && empty( $value ) ) ) { - $this->parent->options[ $key ] = $value; - $changed = true; - if ( isset( $this->parent->compiler_fields[ $key ] ) ) { - $compiler = true; - } - } - } - } - - if ( $changed ) { - $this->parent->set_options( $this->parent->options ); - if ( $compiler ) { - // Have to set this to stop the output of the CSS and typography stuff. - $this->parent->no_output = true; - $this->parent->_enqueue_output(); - do_action( "redux/options/{$this->parent->args['opt_name']}/compiler", $this->parent->options, $this->parent->compilerCSS ); - do_action( "redux/options/{$this->args['opt_name']}/compiler/advanced", $this->parent ); - } - } - - } - - /** - * Enqueue CSS/JS for preview pane - * - * @since 1.0.0 - * @access public - * @global $wp_styles - * @return void - */ - public function _enqueue_previewer() { - wp_enqueue_script( - 'redux-extension-previewer-js', - $this->_extension_url . 'assets/js/preview.js' - ); - - $localize = array( - 'save_pending' => __( 'You have changes that are not saved. Would you like to save them now?', 'redux-framework' ), - 'reset_confirm' => __( 'Are you sure? Resetting will lose all custom values.', 'redux-framework' ), - 'preset_confirm' => __( 'Your current options will be replaced with the values of this preset. Would you like to proceed?', 'redux-framework' ), - 'opt_name' => $this->args['opt_name'], - //'folds' => $this->folds, - 'options' => $this->parent->options, - 'defaults' => $this->parent->options_defaults, - ); - - wp_localize_script( - 'redux-extension-previewer-js', - 'reduxPost', - $localize - ); - } - - /** - * Enqueue CSS/JS for the customizer controls - * - * @since 1.0.0 - * @access public - * @global $wp_styles - * @return void - */ - public function _enqueue() { - global $wp_styles; - - //wp_enqueue_style( 'wp-pointer' ); - //wp_enqueue_script( 'wp-pointer' ); - // Remove when code is in place! - //wp_enqueue_script('redux-extension-customizer-js', $this->_extension_url . 'assets/js/customizer.js'); - // Get styles - //wp_enqueue_style('redux-extension-customizer-css', $this->_extension_url . 'assets/css/customizer.css'); - - $localize = array( - 'save_pending' => __( 'You have changes that are not saved. Would you like to save them now?', 'redux-framework' ), - 'reset_confirm' => __( 'Are you sure? Resetting will lose all custom values.', 'redux-framework' ), - 'preset_confirm' => __( 'Your current options will be replaced with the values of this preset. Would you like to proceed?', 'redux-framework' ), - 'opt_name' => $this->args['opt_name'], - //'folds' => $this->folds, - 'field' => $this->parent->options, - 'defaults' => $this->parent->options_defaults, - ); - - // Values used by the javascript - wp_localize_script( - 'redux-js', - 'redux_opts', - $localize - ); - - do_action( 'redux-enqueue-' . $this->args['opt_name'] ); - - - foreach ( $this->sections as $section ) { - if ( isset( $section['fields'] ) ) { - foreach ( $section['fields'] as $field ) { - if ( isset( $field['type'] ) ) { - $field_class = 'ReduxFramework_' . $field['type']; - - if ( ! class_exists( $field_class ) ) { - $class_file = apply_filters( 'redux-typeclass-load', $this->path . 'inc/fields/' . $field['type'] . '/field_' . $field['type'] . '.php', $field_class ); - if ( $class_file ) { - /** @noinspection PhpIncludeInspection */ - require_once( $class_file ); - } - } - - if ( class_exists( $field_class ) && method_exists( $field_class, 'enqueue' ) ) { - $enqueue = new $field_class( '', '', $this ); - $enqueue->enqueue(); - } - } - } - } - } - } - - /** - * Register Option for use - * - * @since 1.0.0 - * @access public - * @return void - */ - public function _register_setting() { - - } - - /** - * Validate the options before insertion - * - * @since 3.0.0 - * @access public - * - * @param array $plugin_options The options array - * - * @return - */ - public function _field_validation( $value ) { - //print_r( $value ); - //print_r( $_POST ); - - return $value; - - //return $this->parent->_validate_options( $plugin_options ); - } - - /** - * HTML OUTPUT. - * - * @since 1.0.0 - * @access public - * @return void - */ - public function _customizer_html_output() { - - } - } // class - function redux_customizer_custom_validation( $field ) { - return $field; - } - } // if diff --git a/library/admin/ReduxCore/inc/extensions/customizer/extension_customizer.scss b/library/admin/ReduxCore/inc/extensions/customizer/extension_customizer.scss deleted file mode 100644 index 7e05187a..00000000 --- a/library/admin/ReduxCore/inc/extensions/customizer/extension_customizer.scss +++ /dev/null @@ -1,193 +0,0 @@ -.redux-section { - p.customize-section-description { - margin-top: 22px; - word-break: break-word; - &.legacy { - margin-top: 7px; - } - } -} - -.control-section-themes .accordion-section-title { - margin: 0; -} - -#customize-controls { - .customize-info { - margin-bottom: 0; - } - .redux-section .accordion-section-content { - background: #FCFCFC; - } -} - -.redux-section .accordion-section-title i, -.redux-field .accordion-field-title i, -.redux-panel .accordion-section-title i { - margin-right: 5px; -} - -.accordion-section.redux-main { - background: inherit; - margin-left: inherit; - border-left: inherit; - -moz-box-shadow: inherit; - -webkit-box-shadow: inherit; - padding: inherit; - box-shadow: inherit; -} - -.redux_field_th { - padding: 13px 0px 0px 0px; -} - -.redux-main { - .redux-field-container { - padding: 10px 0; - } - .select_wrapper { - float: none; - width: 100%; - display: inline-block; - } - .select2-container { - margin-right: 0 !important; - margin-bottom: 5px !important; - width: 100% !important; - } - .select_wrapper:nth-child(odd) { - margin-right: 0; - } - .redux-option-image { - max-width: 42% !important; - margin-right: 3%; - } - .customize-control { - border-bottom: 1px solid #ddd; - padding-bottom: 4px; - } - .customize-control:last-child { - border-bottom: 0; - padding-bottom: 0; - } - .upload { - width: 100% !important; - } - h3 { - margin-top: inherit; - } - .redux-container-raw { - margin-top: 22px; - word-break: break-word; - padding: 0 !important; - } - .redux-container-password input { - width: 100%; - } -} - -.select2-drop { - z-index: 999999; -} - -.rAdsContainer { - line-height: 0; - border: 0; - /*margin-top: -15px;*/ - /*margin-bottom: -15px;*/ -} - -.rAds { - position: inherit !important; - right: 0 !important; - top: 0 !important; - bottom: 0 !important; - left: 0 !important; - text-align: center; - margin-bottom: 0; - line-height: 0; - -webkit-transition: left ease-in-out .18s; - transition: left ease-in-out .18s; - img { - -webkit-transition: left ease-in-out .18s; - transition: left ease-in-out .18s; - } -} - -@mixin adminCustomizerThemeColorOverrides($highlight-color, $text-color) { - - $menu-highlight-background: $highlight-color; - $menu-highlight-text: $text-color; - - #customize-theme-controls { - .control-section.control-section-redux:hover > h3.accordion-section-title, - .control-section.control-section-redux h3.accordion-section-title:hover, - .control-section.control-section-redux.open h3.accordion-section-title, - .control-section.control-section-redux h3.accordion-section-title:focus, - .control-panel.control-panel-redux:hover > h3.accordion-section-title, - .control-panel.control-panel-redux h3.accordion-section-title:hover, - .control-panel.control-panel-redux.open h3.accordion-section-title, - .control-panel.control-panel-redux h3.accordion-section-title:focus { - color: $text-color; - background: $highlight-color; - &:after { - color: $text-color; - } - } - .control-section.control-panel.control-panel-redux>.accordion-section-title:after { - background: transparent; - border-left: none; - } - .control-panel-redux .customize-panel-back, .redux-section .customize-section-back { - &:hover { - background: $highlight-color; - color: $text-color; - } - } - } -} - -/* Light fresh theme */ -.admin-color-fresh { - @include adminCustomizerThemeColorOverrides(#0073aa, #fff); -} - -/* Ectoplasm theme */ -.admin-color-ectoplasm { - @include adminCustomizerThemeColorOverrides(#a3b745, #fff); -} - -/* Light admin theme */ -.admin-color-light { - @include adminCustomizerThemeColorOverrides(#888, #fff); -} - -/* Blue admin theme */ -.admin-color-blue { - @include adminCustomizerThemeColorOverrides(#096484, #fff); -} - -/* Coffee admin theme */ -.admin-color-coffee { - @include adminCustomizerThemeColorOverrides(#c7a589, #fff); -} - -/* Ectoplasm admin theme */ -.admin-color-ectoplasm { - @include adminCustomizerThemeColorOverrides(#523f6d, #fff); -} - -/* Midnight admin theme */ -.admin-color-midnight { - @include adminCustomizerThemeColorOverrides(#e14d43, #fff); -} - -/* Ocean admin theme */ -.admin-color-ocean { - @include adminCustomizerThemeColorOverrides(#9ebaa0, #fff); -} - -/* Sunrise admin theme */ -.admin-color-sunrise { - @include adminCustomizerThemeColorOverrides(#cf4944, #fff); -} diff --git a/library/admin/ReduxCore/inc/extensions/customizer/inc/customizer_control.php b/library/admin/ReduxCore/inc/extensions/customizer/inc/customizer_control.php deleted file mode 100644 index 34930bf2..00000000 --- a/library/admin/ReduxCore/inc/extensions/customizer/inc/customizer_control.php +++ /dev/null @@ -1,43 +0,0 @@ -redux_id = str_replace( 'customize-control-', '', 'customize-control-' . str_replace( '[', '-', str_replace( ']', '', $this->id ) ) ); - $class = 'customize-control redux-group-tab redux-field customize-control-' . $this->type; - ?> -
  • - link() ?> - value=""/> - render_content(); ?> -
  • - redux_id, $this ); - } - - public function label() { - // The label has already been sanitized in the Fields class, no need to re-sanitize it. - echo $this->label; - } - - public function description() { - if ( ! empty( $this->description ) ) { - // The description has already been sanitized in the Fields class, no need to re-sanitize it. - echo '' . $this->description . ''; - } - } - - public function title() { - echo ''; - $this->label(); - $this->description(); - echo ''; - } - } - } diff --git a/library/admin/ReduxCore/inc/extensions/customizer/inc/customizer_devs.php b/library/admin/ReduxCore/inc/extensions/customizer/inc/customizer_devs.php deleted file mode 100644 index 8d76717e..00000000 --- a/library/admin/ReduxCore/inc/extensions/customizer/inc/customizer_devs.php +++ /dev/null @@ -1,43 +0,0 @@ - -
  • - $key = $args[ $key ]; - } - } - $this->manager = $manager; - $this->id = $id; - if ( empty( $this->active_callback ) ) { - $this->active_callback = array( $this, 'active_callback' ); - } - self::$instance_count += 1; - $this->instance_number = self::$instance_count; - - $this->sections = array(); // Users cannot customize the $sections array. - - // TODO Redux addition - if ( isset( $args['section'] ) ) { - $this->section = $args['section']; - $this->description = isset( $this->section['desc'] ) ? $this->section['desc'] : ''; - $this->opt_name = isset( $args['opt_name'] ) ? $args['opt_name'] : ''; - } - // TODO END Redux Addition - } - - /** - * WP < 4.3 Render - * - * @since - * @access protected - */ - protected function render() { - global $wp_version; - $version = explode( '-', $wp_version ); - if ( version_compare( $version[0], '4.3', '<' ) ) { - $this->render_fallback(); - } - - } - - protected function render_fallback() { - $classes = 'accordion-section redux-main redux-panel control-section control-panel control-panel-' . $this->type; - ?> -
  • -

    - title, array( - 'em' => array(), - 'i' => array(), - 'strong' => array(), - 'span' => array( - 'class' => array(), - 'style' => array(), - ), - ) ); - ?> - -

    -
      - - render_content(); ?> -
      -
    -
  • - -
  • -
    - ' . esc_html( $this->title ) . '' ); - ?> -
    - description ) ) : ?> -
    - description; ?> -
    - -
  • - -
  • - -
    - {{ data.title }}' ); - ?> - <# if ( data.description ) { #> - - <# } #> -
    - <# if ( data.description ) { #> -
    - {{{ data.description }}} -
    - <# } #> -
  • - $key = $args[ $key ]; - } - } - - $this->manager = $manager; - $this->id = $id; - if ( empty( $this->active_callback ) ) { - $this->active_callback = array( $this, 'active_callback' ); - } - self::$instance_count += 1; - $this->instance_number = self::$instance_count; - - $this->controls = array(); // Users cannot customize the $controls array. - - // TODO Redux addition - if ( isset( $args['section'] ) ) { - $this->section = $args['section']; - $this->description = isset( $this->section['desc'] ) ? $this->section['desc'] : ''; - $this->opt_name = isset( $args['opt_name'] ) ? $args['opt_name'] : ''; - } - } - - /** - * An Underscore (JS) template for rendering this section. - * Class variables for this section class are available in the `data` JS object; - * export custom variables by overriding {@see WP_Customize_Section::json()}. - * - * @see WP_Customize_Section::print_template() - * @since 4.3.0 - */ - protected function render_template() { - ?> -
  • -

    - {{ data.title }} - -

    -
      - -
    • -
      - -

      - - {{{ data.customizeAction }}} - {{ data.title }} -

      -
      - <# if ( data.description ) { #> -

      {{{ data.description }}}

      - <# } #> - opt_name ) && isset( $this->section ) ) { - do_action( "redux/page/{$this->opt_name}/section/before", $this->section ); - } - ?> -
    • -
    -
  • - type; - ?> -
  • -

    - title, array( - 'em' => array(), - 'i' => array(), - 'strong' => array(), - 'span' => array( - 'class' => array(), - 'style' => array(), - ), - ) ); - ?> - -

    -
      - opt_name ) && isset( $this->section ) ) { - do_action( "redux/page/{$this->opt_name}/section/before", $this->section ); - } - ?> - description ) ) : ?> -
    • -

      description; ?>

      -
    • - -
    -
  • - render_fallback(); - } - } - - } - - diff --git a/library/admin/ReduxCore/inc/extensions/import_export/extension_import_export.php b/library/admin/ReduxCore/inc/extensions/import_export/extension_import_export.php deleted file mode 100644 index ba813c44..00000000 --- a/library/admin/ReduxCore/inc/extensions/import_export/extension_import_export.php +++ /dev/null @@ -1,209 +0,0 @@ -. - * - * @package ReduxFramework - * @author Dovy Paukstys (dovy) - * @version 4.0.0 - */ - -// Exit if accessed directly - if ( ! defined( 'ABSPATH' ) ) { - exit; - } - -// Don't duplicate me! - if ( ! class_exists( 'ReduxFramework_extension_import_export' ) ) { - - - /** - * Main ReduxFramework import_export extension class - * - * @since 3.1.6 - */ - class ReduxFramework_extension_import_export { - - // Protected vars - protected $parent; - public $extension_url; - public $extension_dir; - public static $theInstance; - public static $version = "4.0"; - public $is_field = false; - - /** - * Class Constructor. Defines the args for the extions class - * - * @since 1.0.0 - * @access public - * - * @param array $sections Panel sections. - * @param array $args Class constructor arguments. - * @param array $extra_tabs Extra panel tabs. - * - * @return void - */ - public function __construct( $parent ) { - - $this->parent = $parent; - if ( empty( $this->extension_dir ) ) { - //$this->extension_dir = trailingslashit( str_replace( '\\', '/', dirname( __FILE__ ) ) ); - } - $this->field_name = 'import_export'; - - self::$theInstance = $this; - - add_action( "wp_ajax_redux_link_options-" . $this->parent->args['opt_name'], array( - $this, - "link_options" - ) ); - add_action( "wp_ajax_nopriv_redux_link_options-" . $this->parent->args['opt_name'], array( - $this, - "link_options" - ) ); - - add_action( "wp_ajax_redux_download_options-" . $this->parent->args['opt_name'], array( - $this, - "download_options" - ) ); - add_action( "wp_ajax_nopriv_redux_download_options-" . $this->parent->args['opt_name'], array( - $this, - "download_options" - ) ); - - do_action( "redux/options/{$this->parent->args['opt_name']}/import", array( $this, 'remove_cookie' ) ); - - $this->is_field = Redux_Helpers::isFieldInUse( $parent, 'import_export' ); - - if ( ! $this->is_field && $this->parent->args['show_import_export'] ) { - $this->add_section(); - } - - add_filter( 'redux/' . $this->parent->args['opt_name'] . '/field/class/' . $this->field_name, array( - &$this, - 'overload_field_path' - ) ); // Adds the local field - - add_filter( 'upload_mimes', array( - $this, - 'custom_upload_mimes' - ) ); - - } - - /** - * Adds the appropriate mime types to WordPress - * - * @param array $existing_mimes - * - * @return array - */ - function custom_upload_mimes( $existing_mimes = array() ) { - $existing_mimes['redux'] = 'application/redux'; - - return $existing_mimes; - } - - public function add_section() { - $this->parent->sections[] = array( - 'id' => 'import/export', - 'title' => __( 'Import / Export', 'redux-framework' ), - 'heading' => '', - 'icon' => 'el el-refresh', - 'customizer' => false, - 'fields' => array( - array( - 'id' => 'redux_import_export', - 'type' => 'import_export', - //'class' => 'redux-field-init redux_remove_th', - //'title' => '', - 'full_width' => true, - ) - ), - ); - } - - function link_options() { - if ( ! isset( $_GET['secret'] ) || $_GET['secret'] != md5( md5( AUTH_KEY . SECURE_AUTH_KEY ) . '-' . $this->parent->args['opt_name'] ) ) { - wp_die( 'Invalid Secret for options use' ); - exit; - } - - $var = $this->parent->options; - $var['redux-backup'] = '1'; - if ( isset( $var['REDUX_imported'] ) ) { - unset( $var['REDUX_imported'] ); - } - - echo json_encode( $var ); - - die(); - } - - public function download_options() { - if ( ! isset( $_GET['secret'] ) || $_GET['secret'] != md5( md5( AUTH_KEY . SECURE_AUTH_KEY ) . '-' . $this->parent->args['opt_name'] ) ) { - wp_die( 'Invalid Secret for options use' ); - exit; - } - - $this->parent->get_options(); - $backup_options = $this->parent->options; - $backup_options['redux-backup'] = '1'; - if ( isset( $var['REDUX_imported'] ) ) { - unset( $var['REDUX_imported'] ); - } - - // No need to escape this, as it's been properly escaped previously and through json_encode - $content = json_encode( $backup_options ); - - if ( isset( $_GET['action'] ) && $_GET['action'] == 'redux_download_options-' . $this->parent->args['opt_name'] ) { - header( 'Content-Description: File Transfer' ); - header( 'Content-type: application/txt' ); - header( 'Content-Disposition: attachment; filename="redux_options_' . $this->parent->args['opt_name'] . '_backup_' . date( 'd-m-Y' ) . '.json"' ); - header( 'Content-Transfer-Encoding: binary' ); - header( 'Expires: 0' ); - header( 'Cache-Control: must-revalidate' ); - header( 'Pragma: public' ); - - echo $content; - exit; - } else { - header( "Expires: Mon, 26 Jul 1997 05:00:00 GMT" ); - header( "Last-Modified: " . gmdate( "D, d M Y H:i:s" ) . "GMT" ); - header( 'Expires: Sat, 26 Jul 1997 05:00:00 GMT' ); - header( 'Cache-Control: no-store, no-cache, must-revalidate' ); - header( 'Cache-Control: post-check=0, pre-check=0', false ); - header( 'Pragma: no-cache' ); - - // Can't include the type. Thanks old Firefox and IE. BAH. - //header("Content-type: application/json"); - echo $content; - exit; - } - } - - // Forces the use of the embeded field path vs what the core typically would use - public function overload_field_path( $field ) { - return dirname( __FILE__ ) . '/' . $this->field_name . '/field_' . $this->field_name . '.php'; - } - - public function remove_cookie() { - // Remove the import/export tab cookie. - if ( $_COOKIE['redux_current_tab'] == 'import_export_default' ) { - setcookie( 'redux_current_tab', '', 1, '/' ); - $_COOKIE['redux_current_tab'] = 1; - } - } - - } - } diff --git a/library/admin/ReduxCore/inc/extensions/import_export/import_export/field_import_export.css b/library/admin/ReduxCore/inc/extensions/import_export/import_export/field_import_export.css deleted file mode 100644 index 70f310d3..00000000 --- a/library/admin/ReduxCore/inc/extensions/import_export/import_export/field_import_export.css +++ /dev/null @@ -1 +0,0 @@ -#redux-import-link-wrapper,#redux-import-code-wrapper{display:none}#redux-export-code,#redux-export-link-value{display:none}#redux-import-action span{color:#B94A48} diff --git a/library/admin/ReduxCore/inc/extensions/import_export/import_export/field_import_export.js b/library/admin/ReduxCore/inc/extensions/import_export/import_export/field_import_export.js deleted file mode 100644 index 9ca632e5..00000000 --- a/library/admin/ReduxCore/inc/extensions/import_export/import_export/field_import_export.js +++ /dev/null @@ -1,200 +0,0 @@ -/*global jQuery, document, redux*/ - -(function( $ ) { - "use strict"; - - redux.field_objects = redux.field_objects || {}; - redux.field_objects.import_export = redux.field_objects.import_export || {}; - - redux.field_objects.import_export.init = function( selector ) { - if ( !selector ) { - selector = $( document ).find( ".redux-group-tab:visible" ).find( '.redux-container-import_export:visible' ); - } - - $( selector ).each( - function() { - var el = $( this ); - var parent = el; - if ( !el.hasClass( 'redux-field-container' ) ) { - parent = el.parents( '.redux-field-container:first' ); - } - if ( parent.is( ":hidden" ) ) { // Skip hidden fields - return; - } - if ( parent.hasClass( 'redux-field-init' ) ) { - parent.removeClass( 'redux-field-init' ); - } else { - return; - } - el.each( - function() { - $( '#redux-import' ).click( - function( e ) { - if ( $( '#import-code-value' ).val() === "" && $( '#import-link-value' ).val() === "" ) { - e.preventDefault(); - return false; - } - window.onbeforeunload = null; - redux.args.ajax_save = false; - } - ); - - $( this ).find( '#redux-import-code-button' ).click( - function() { - var $el = $( '#redux-import-code-wrapper' ); - if ( $( '#redux-import-link-wrapper' ).is( ':visible' ) ) { - $( '#import-link-value' ).text( '' ); - $( '#redux-import-link-wrapper' ).slideUp( - 'fast', function() { - $el.slideDown( - 'fast', function() { - $( '#import-code-value' ).focus(); - } - ); - } - ); - } else { - if ( $el.is( ':visible' ) ) { - $el.slideUp(); - } else { - $el.slideDown( - 'medium', function() { - $( '#import-code-value' ).focus(); - } - ); - } - } - } - ); - - $( this ).find( '#redux-import-link-button' ).click( - function() { - var $el = $( '#redux-import-link-wrapper' ); - if ( $( '#redux-import-code-wrapper' ).is( ':visible' ) ) { - $( '#import-code-value' ).text( '' ); - $( '#redux-import-code-wrapper' ).slideUp( - 'fast', function() { - $el.slideDown( - 'fast', function() { - $( '#import-link-value' ).focus(); - } - ); - } - ); - } else { - if ( $el.is( ':visible' ) ) { - $el.slideUp(); - } else { - $el.slideDown( - 'medium', function() { - $( '#import-link-value' ).focus(); - } - ); - } - } - } - ); - - $( this ).find( '#redux-export-code-copy' ).click( - function() { - var $el = $( '#redux-export-code' ); - if ( $( '#redux-export-link-value' ).is( ':visible' ) ) { - $( '#redux-export-link-value' ).slideUp( - 'fast', function() { - $el.slideDown( - 'medium', function() { - var options = redux.options; - options['redux-backup'] = 1; - $( this ).text( JSON.stringify( options ) ).focus().select(); - } - ); - } - ); - } else { - if ( $el.is( ':visible' ) ) { - $el.slideUp().text( '' ); - } else { - $el.slideDown( - 'medium', function() { - var options = redux.options; - options['redux-backup'] = 1; - $( this ).text( JSON.stringify( options ) ).focus().select(); - } - ); - } - } - } - ); - - $( this ).find( 'textarea' ).focusout( - function() { - var $id = $( this ).attr( 'id' ); - var $el = $( this ); - var $container = $el; - if ( $id == "import-link-value" || $id == "import-code-value" ) { - $container = $( this ).parent(); - } - $container.slideUp( - 'medium', function() { - if ( $id != "redux-export-link-value" ) { - $el.text( '' ); - } - } - ); - } - ); - - - $( this ).find( '#redux-export-link' ).click( - function() { - var $el = $( '#redux-export-link-value' ); - if ( $( '#redux-export-code' ).is( ':visible' ) ) { - $( '#redux-export-code' ).slideUp( - 'fast', function() { - $el.slideDown().focus().select(); - } - ); - } else { - if ( $el.is( ':visible' ) ) { - $el.slideUp(); - } else { - $el.slideDown( - 'medium', function() { - $( this ).focus().select(); - } - ); - } - - } - } - ); - - var textBox1 = document.getElementById( "redux-export-code" ); - textBox1.onfocus = function() { - textBox1.select(); - // Work around Chrome's little problem - textBox1.onmouseup = function() { - // Prevent further mouseup intervention - textBox1.onmouseup = null; - return false; - }; - }; - var textBox2 = document.getElementById( "import-code-value" ); - textBox2.onfocus = function() { - textBox2.select(); - // Work around Chrome's little problem - textBox2.onmouseup = function() { - // Prevent further mouseup intervention - textBox2.onmouseup = null; - return false; - }; - }; - - } - ); - } - ); - }; -})( jQuery ); - - diff --git a/library/admin/ReduxCore/inc/extensions/import_export/import_export/field_import_export.min.js b/library/admin/ReduxCore/inc/extensions/import_export/import_export/field_import_export.min.js deleted file mode 100644 index 4b48dd70..00000000 --- a/library/admin/ReduxCore/inc/extensions/import_export/import_export/field_import_export.min.js +++ /dev/null @@ -1 +0,0 @@ -!function(a){"use strict";redux.field_objects=redux.field_objects||{},redux.field_objects.import_export=redux.field_objects.import_export||{},redux.field_objects.import_export.init=function(b){b||(b=a(document).find(".redux-group-tab:visible").find(".redux-container-import_export:visible")),a(b).each(function(){var b=a(this),c=b;b.hasClass("redux-field-container")||(c=b.parents(".redux-field-container:first")),c.is(":hidden")||c.hasClass("redux-field-init")&&(c.removeClass("redux-field-init"),b.each(function(){a("#redux-import").click(function(b){return""===a("#import-code-value").val()&&""===a("#import-link-value").val()?(b.preventDefault(),!1):(window.onbeforeunload=null,void(redux.args.ajax_save=!1))}),a(this).find("#redux-import-code-button").click(function(){var b=a("#redux-import-code-wrapper");a("#redux-import-link-wrapper").is(":visible")?(a("#import-link-value").text(""),a("#redux-import-link-wrapper").slideUp("fast",function(){b.slideDown("fast",function(){a("#import-code-value").focus()})})):b.is(":visible")?b.slideUp():b.slideDown("medium",function(){a("#import-code-value").focus()})}),a(this).find("#redux-import-link-button").click(function(){var b=a("#redux-import-link-wrapper");a("#redux-import-code-wrapper").is(":visible")?(a("#import-code-value").text(""),a("#redux-import-code-wrapper").slideUp("fast",function(){b.slideDown("fast",function(){a("#import-link-value").focus()})})):b.is(":visible")?b.slideUp():b.slideDown("medium",function(){a("#import-link-value").focus()})}),a(this).find("#redux-export-code-copy").click(function(){var b=a("#redux-export-code");a("#redux-export-link-value").is(":visible")?a("#redux-export-link-value").slideUp("fast",function(){b.slideDown("medium",function(){var b=redux.options;b["redux-backup"]=1,a(this).text(JSON.stringify(b)).focus().select()})}):b.is(":visible")?b.slideUp().text(""):b.slideDown("medium",function(){var b=redux.options;b["redux-backup"]=1,a(this).text(JSON.stringify(b)).focus().select()})}),a(this).find("textarea").focusout(function(){var b=a(this).attr("id"),c=a(this),d=c;("import-link-value"==b||"import-code-value"==b)&&(d=a(this).parent()),d.slideUp("medium",function(){"redux-export-link-value"!=b&&c.text("")})}),a(this).find("#redux-export-link").click(function(){var b=a("#redux-export-link-value");a("#redux-export-code").is(":visible")?a("#redux-export-code").slideUp("fast",function(){b.slideDown().focus().select()}):b.is(":visible")?b.slideUp():b.slideDown("medium",function(){a(this).focus().select()})});var b=document.getElementById("redux-export-code");b.onfocus=function(){b.select(),b.onmouseup=function(){return b.onmouseup=null,!1}};var c=document.getElementById("import-code-value");c.onfocus=function(){c.select(),c.onmouseup=function(){return c.onmouseup=null,!1}}}))})}}(jQuery); \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/extensions/import_export/import_export/field_import_export.php b/library/admin/ReduxCore/inc/extensions/import_export/import_export/field_import_export.php deleted file mode 100644 index 11eae0cd..00000000 --- a/library/admin/ReduxCore/inc/extensions/import_export/import_export/field_import_export.php +++ /dev/null @@ -1,177 +0,0 @@ -. - * - * @package ReduxFramework - * @author Dovy Paukstys - * @version 3.1.5 - */ - -// Exit if accessed directly - if ( ! defined( 'ABSPATH' ) ) { - exit; - } - -// Don't duplicate me! - if ( ! class_exists( 'ReduxFramework_import_export' ) ) { - - /** - * Main ReduxFramework_import_export class - * - * @since 1.0.0 - */ - class ReduxFramework_import_export extends ReduxFramework { - - /** - * Field Constructor. - * Required - must call the parent constructor, then assign field and value to vars, and obviously call the render field function - * - * @since 1.0.0 - * @access public - * @return void - */ - function __construct( $field = array(), $value = '', $parent ) { - - $this->parent = $parent; - $this->field = $field; - $this->value = $value; - $this->is_field = $this->parent->extensions['import_export']->is_field; - - $this->extension_dir = ReduxFramework::$_dir . 'inc/extensions/import_export/'; - $this->extension_url = ReduxFramework::$_url . 'inc/extensions/import_export/'; - - // Set default args for this field to avoid bad indexes. Change this to anything you use. - $defaults = array( - 'options' => array(), - 'stylesheet' => '', - 'output' => true, - 'enqueue' => true, - 'enqueue_frontend' => true - ); - $this->field = wp_parse_args( $this->field, $defaults ); - - } - - /** - * Field Render Function. - * Takes the vars and outputs the HTML for the field in the settings - * - * @since 1.0.0 - * @access public - * @return void - */ - public function render() { - - $secret = md5( md5( AUTH_KEY . SECURE_AUTH_KEY ) . '-' . $this->parent->args['opt_name'] ); - - // No errors please - $defaults = array( - 'full_width' => true, - 'overflow' => 'inherit', - ); - - $this->field = wp_parse_args( $this->field, $defaults ); - - $bDoClose = false; - - // $this->parent->args['opt_name'] & $this->field['id'] are sanitized in the ReduxFramework class, no need to re-sanitize it. - $id = $this->parent->args['opt_name'] . '-' . $this->field['id']; - - // $this->field['type'] && $this->field['id'] is sanitized in the ReduxFramework class, no need to re-sanitize it. - ?> -

    - -

    - -
    -

    - parent->args['opt_name'] is sanitized in the ReduxFramework class, no need to re-sanitize it. ?> - -
    - - - -

      

    - -
    -
     
    -

    - -
    -

    -
    - parent->args['opt_name'] is sanitized in the ReduxFramework class, no need to re-sanitize it. - $link = esc_url( admin_url( 'admin-ajax.php?action=redux_download_options-' . $this->parent->args['opt_name'] . '&secret=' . $secret ) ); - ?> -

    - - - -

    - -

    - - - - extension_url . 'import_export/field_import_export' . Redux_Functions::isMin() . '.js', - array( 'jquery' ), - ReduxFramework_extension_import_export::$version, - true - ); - - wp_enqueue_style( - 'redux-import-export', - $this->extension_url . 'import_export/field_import_export.css', - time(), - true - ); - - } - - /** - * Output Function. - * Used to enqueue to the front-end - * - * @since 1.0.0 - * @access public - * @return void - */ - public function output() { - - if ( $this->field['enqueue_frontend'] ) { - - } - - } - - } - } diff --git a/library/admin/ReduxCore/inc/extensions/import_export/import_export/field_import_export.scss b/library/admin/ReduxCore/inc/extensions/import_export/import_export/field_import_export.scss deleted file mode 100644 index ca285843..00000000 --- a/library/admin/ReduxCore/inc/extensions/import_export/import_export/field_import_export.scss +++ /dev/null @@ -1,13 +0,0 @@ -#redux-import-link-wrapper, -#redux-import-code-wrapper { - display: none; -} - -#redux-export-code, -#redux-export-link-value { - display: none; -} - -#redux-import-action span { - color: #B94A48; -} \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/extensions/options_object/extension_options_object.php b/library/admin/ReduxCore/inc/extensions/options_object/extension_options_object.php deleted file mode 100644 index efc998e8..00000000 --- a/library/admin/ReduxCore/inc/extensions/options_object/extension_options_object.php +++ /dev/null @@ -1,101 +0,0 @@ -. - * - * @package ReduxFramework - * @author Kevin Provance (kprovance) - * @version 4.0.0 - */ - -// Exit if accessed directly - if ( ! defined( 'ABSPATH' ) ) { - exit; - } - -// Don't duplicate me! - if ( ! class_exists( 'ReduxFramework_Extension_options_object' ) ) { - - - /** - * Main ReduxFramework options_object extension class - * - * @since 3.1.6 - */ - class ReduxFramework_Extension_options_object { - - // Protected vars - protected $parent; - public $extension_url; - public $extension_dir; - public static $theInstance; - public static $version = "4.0"; - public $is_field = false; - - /** - * Class Constructor. Defines the args for the extions class - * - * @since 1.0.0 - * @access public - * - * @param array $sections Panel sections. - * @param array $args Class constructor arguments. - * @param array $extra_tabs Extra panel tabs. - * - * @return void - */ - public function __construct( $parent ) { - - $this->parent = $parent; - if ( empty( $this->extension_dir ) ) { - //$this->extension_dir = trailingslashit( str_replace( '\\', '/', dirname( __FILE__ ) ) ); - } - $this->field_name = 'options_object'; - - - self::$theInstance = $this; - - $this->is_field = Redux_Helpers::isFieldInUse($parent, 'options_object'); - - if ( !$this->is_field && $this->parent->args['dev_mode'] && $this->parent->args['show_options_object'] ) { - $this->add_section(); - } - - add_filter( 'redux/' . $this->parent->args['opt_name'] . '/field/class/' . $this->field_name, array( - &$this, - 'overload_field_path' - ) ); // Adds the local field - } - - public function add_section() { - $this->parent->sections[] = array( - 'id' => 'options-object', - 'title' => __( 'Options Object', 'redux-framework' ), - 'heading' => '', - 'icon' => 'el el-info-circle', - 'customizer' => false, - 'fields' => array( - array( - 'id' => 'redux_options_object', - 'type'=> 'options_object', - 'title' => '', - ) - ), - ); - } - - // Forces the use of the embeded field path vs what the core typically would use - public function overload_field_path( $field ) { - return dirname( __FILE__ ) . '/' . $this->field_name . '/field_' . $this->field_name . '.php'; - } - } // class - } // if diff --git a/library/admin/ReduxCore/inc/extensions/options_object/options_object/field_options_object.css b/library/admin/ReduxCore/inc/extensions/options_object/options_object/field_options_object.css deleted file mode 100644 index 80207185..00000000 --- a/library/admin/ReduxCore/inc/extensions/options_object/options_object/field_options_object.css +++ /dev/null @@ -1 +0,0 @@ -#redux-object-browser{overflow:auto;word-wrap:break-word;max-height:600px;max-width:100%} diff --git a/library/admin/ReduxCore/inc/extensions/options_object/options_object/field_options_object.js b/library/admin/ReduxCore/inc/extensions/options_object/options_object/field_options_object.js deleted file mode 100644 index b83ab4b6..00000000 --- a/library/admin/ReduxCore/inc/extensions/options_object/options_object/field_options_object.js +++ /dev/null @@ -1,44 +0,0 @@ -/*global redux_change, redux*/ - -(function( $ ) { - "use strict"; - - redux.field_objects = redux.field_objects || {}; - redux.field_objects.options_object = redux.field_objects.options_object || {}; - -// $( document ).ready( -// function() { -// redux.field_objects.import_export.init(); -// } -// ); - - redux.field_objects.options_object.init = function( selector ) { - - if ( !selector ) { - selector = $( document ).find( '.redux-container-options_object' ); - } - - var parent = selector; - - if ( !selector.hasClass( 'redux-field-container' ) ) { - parent = selector.parents( '.redux-field-container:first' ); - } - - if ( parent.hasClass( 'redux-field-init' ) ) { - parent.removeClass( 'redux-field-init' ); - } else { - return; - } - - $( '#consolePrintObject' ).on( - 'click', function( e ) { - e.preventDefault(); - console.log( $.parseJSON( $( "#redux-object-json" ).html() ) ); - } - ); - - if ( typeof jsonView === 'function' ) { - jsonView( '#redux-object-json', '#redux-object-browser' ); - } - }; -})( jQuery ); \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/extensions/options_object/options_object/field_options_object.min.js b/library/admin/ReduxCore/inc/extensions/options_object/options_object/field_options_object.min.js deleted file mode 100644 index 77bd644e..00000000 --- a/library/admin/ReduxCore/inc/extensions/options_object/options_object/field_options_object.min.js +++ /dev/null @@ -1 +0,0 @@ -!function(a){"use strict";redux.field_objects=redux.field_objects||{},redux.field_objects.options_object=redux.field_objects.options_object||{},redux.field_objects.options_object.init=function(b){b||(b=a(document).find(".redux-container-options_object"));var c=b;b.hasClass("redux-field-container")||(c=b.parents(".redux-field-container:first")),c.hasClass("redux-field-init")&&(c.removeClass("redux-field-init"),a("#consolePrintObject").on("click",function(b){b.preventDefault(),console.log(a.parseJSON(a("#redux-object-json").html()))}),"function"==typeof jsonView&&jsonView("#redux-object-json","#redux-object-browser"))}}(jQuery); \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/extensions/options_object/options_object/field_options_object.php b/library/admin/ReduxCore/inc/extensions/options_object/options_object/field_options_object.php deleted file mode 100644 index 4ee4616f..00000000 --- a/library/admin/ReduxCore/inc/extensions/options_object/options_object/field_options_object.php +++ /dev/null @@ -1,164 +0,0 @@ -. - * - * @package ReduxFramework - * @author Kevin Provance (kprovance) - * @version 3.5.4 - */ - -// Exit if accessed directly - if ( ! defined( 'ABSPATH' ) ) { - exit; - } - -// Don't duplicate me! - if ( ! class_exists( 'ReduxFramework_options_object' ) ) { - - /** - * Main ReduxFramework_options_object class - * - * @since 1.0.0 - */ - class ReduxFramework_options_object { - - /** - * Field Constructor. - * Required - must call the parent constructor, then assign field and value to vars, and obviously call the render field function - * - * @since 1.0.0 - * @access public - * @return void - */ - function __construct( $field = array(), $value = '', $parent ) { - - $this->parent = $parent; - $this->field = $field; - $this->value = $value; - $this->is_field = $this->parent->extensions['options_object']->is_field; - - $this->extension_dir = ReduxFramework::$_dir . 'inc/extensions/options_object/'; - $this->extension_url = ReduxFramework::$_url . 'inc/extensions/options_object/'; - - // Set default args for this field to avoid bad indexes. Change this to anything you use. - $defaults = array( - 'options' => array(), - 'stylesheet' => '', - 'output' => true, - 'enqueue' => true, - 'enqueue_frontend' => true - ); - $this->field = wp_parse_args( $this->field, $defaults ); - - } - - /** - * Field Render Function. - * Takes the vars and outputs the HTML for the field in the settings - * - * @since 1.0.0 - * @access public - * @return void - */ - public function render() { - if ( version_compare( phpversion(), "5.3.0", ">=" ) ) { - $json = json_encode( $this->parent->options, true ); - } else { - $json = json_encode( $this->parent->options ); - } - - $defaults = array( - 'full_width' => true, - 'overflow' => 'inherit', - ); - - $this->field = wp_parse_args( $this->field, $defaults ); - - if ( $this->is_field ) { - $fullWidth = $this->field['full_width']; - } - - $bDoClose = false; - - $id = $this->parent->args['opt_name'] . '-' . $this->field['id']; - - if ( ! $this->is_field || ( $this->is_field && false == $fullWidth ) ) { ?> - - - -
    - -
    -

    -
    -
    - - -
    - -
    - - - - -
    -extension_url . 'options_object/field_options_object' . Redux_Functions::isMin() . '.js', - array( 'jquery' ), - ReduxFramework_extension_options_object::$version, - true - ); - - wp_enqueue_style( - 'redux-options-object', - $this->extension_url . 'options_object/field_options_object.css', - array(), - time(), - 'all' - ); - } - - /** - * Output Function. - * Used to enqueue to the front-end - * - * @since 1.0.0 - * @access public - * @return void - */ - public function output() { - - if ( $this->field['enqueue_frontend'] ) { - - } - } - } - } diff --git a/library/admin/ReduxCore/inc/extensions/options_object/options_object/field_options_object.scss b/library/admin/ReduxCore/inc/extensions/options_object/options_object/field_options_object.scss deleted file mode 100644 index 35fc9dcb..00000000 --- a/library/admin/ReduxCore/inc/extensions/options_object/options_object/field_options_object.scss +++ /dev/null @@ -1,7 +0,0 @@ -#redux-object-browser { - overflow: auto; - word-wrap: break-word; - max-height: 600px; - max-width: 100%; -} - diff --git a/library/admin/ReduxCore/inc/fields/ace_editor/field_ace_editor.css b/library/admin/ReduxCore/inc/fields/ace_editor/field_ace_editor.css deleted file mode 100644 index 01f9e6f9..00000000 --- a/library/admin/ReduxCore/inc/fields/ace_editor/field_ace_editor.css +++ /dev/null @@ -1 +0,0 @@ -.redux-container-ace_editor .ace-wrapper{position:static}.redux-container-ace_editor .ace_editor{height:200px;-webkit-border-radius:3px;-moz-border-radius:3px;border-radius:3px}.redux-container-ace_editor .ace_gutter{z-index:1 !important} diff --git a/library/admin/ReduxCore/inc/fields/ace_editor/field_ace_editor.js b/library/admin/ReduxCore/inc/fields/ace_editor/field_ace_editor.js deleted file mode 100644 index 4c2e398f..00000000 --- a/library/admin/ReduxCore/inc/fields/ace_editor/field_ace_editor.js +++ /dev/null @@ -1,58 +0,0 @@ -/*global jQuery, document, redux*/ - -(function( $ ) { - "use strict"; - - redux.field_objects = redux.field_objects || {}; - redux.field_objects.ace_editor = redux.field_objects.ace_editor || {}; - - redux.field_objects.ace_editor.init = function( selector ) { - if ( !selector ) { - selector = $( document ).find( ".redux-group-tab:visible" ).find( '.redux-container-ace_editor:visible' ); - } - - $( selector ).each( - function() { - var el = $( this ); - var parent = el; - if ( !el.hasClass( 'redux-field-container' ) ) { - parent = el.parents( '.redux-field-container:first' ); - } - if ( parent.is( ":hidden" ) ) { // Skip hidden fields - return; - } - if ( parent.hasClass( 'redux-field-init' ) ) { - parent.removeClass( 'redux-field-init' ); - } else { - return; - } - el.find( '.ace-editor' ).each( - function( index, element ) { - var area = element; - var params = JSON.parse( $( this ).parent().find( '.localize_data' ).val() ); - var editor = $( element ).attr( 'data-editor' ); - - var aceeditor = ace.edit( editor ); - aceeditor.setTheme( "ace/theme/" + jQuery( element ).attr( 'data-theme' ) ); - aceeditor.getSession().setMode( "ace/mode/" + $( element ).attr( 'data-mode' ) ); - var parent = ''; - if ( el.hasClass( 'redux-field-container' ) ) { - parent = el.attr( 'data-id' ); - } else { - parent = el.parents( '.redux-field-container:first' ).attr( 'data-id' ); - } - - aceeditor.setOptions( params ); - aceeditor.on( - 'change', function( e ) { - $( '#' + area.id ).val( aceeditor.getSession().getValue() ); - redux_change( $( element ) ); - aceeditor.resize(); - } - ); - } - ); - } - ); - }; -})( jQuery ); \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/ace_editor/field_ace_editor.min.js b/library/admin/ReduxCore/inc/fields/ace_editor/field_ace_editor.min.js deleted file mode 100644 index b410a26f..00000000 --- a/library/admin/ReduxCore/inc/fields/ace_editor/field_ace_editor.min.js +++ /dev/null @@ -1 +0,0 @@ -!function(a){"use strict";redux.field_objects=redux.field_objects||{},redux.field_objects.ace_editor=redux.field_objects.ace_editor||{},redux.field_objects.ace_editor.init=function(b){b||(b=a(document).find(".redux-group-tab:visible").find(".redux-container-ace_editor:visible")),a(b).each(function(){var b=a(this),c=b;b.hasClass("redux-field-container")||(c=b.parents(".redux-field-container:first")),c.is(":hidden")||c.hasClass("redux-field-init")&&(c.removeClass("redux-field-init"),b.find(".ace-editor").each(function(c,d){var e=d,f=JSON.parse(a(this).parent().find(".localize_data").val()),g=a(d).attr("data-editor"),h=ace.edit(g);h.setTheme("ace/theme/"+jQuery(d).attr("data-theme")),h.getSession().setMode("ace/mode/"+a(d).attr("data-mode"));var i="";i=b.hasClass("redux-field-container")?b.attr("data-id"):b.parents(".redux-field-container:first").attr("data-id"),h.setOptions(f),h.on("change",function(b){a("#"+e.id).val(h.getSession().getValue()),redux_change(a(d)),h.resize()})}))})}}(jQuery); \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/ace_editor/field_ace_editor.php b/library/admin/ReduxCore/inc/fields/ace_editor/field_ace_editor.php deleted file mode 100644 index 4528f9ea..00000000 --- a/library/admin/ReduxCore/inc/fields/ace_editor/field_ace_editor.php +++ /dev/null @@ -1,138 +0,0 @@ -. - * - * @package Redux_Field - * @subpackage ACE_Editor - * @version 3.0.0 - */ - -// Exit if accessed directly - if ( ! defined( 'ABSPATH' ) ) { - exit; - } - -// Don't duplicate me! - if ( ! class_exists( 'ReduxFramework_ace_editor' ) ) { - class ReduxFramework_ace_editor { - - /** - * Field Constructor. - * Required - must call the parent constructor, then assign field and value to vars, and obviously call the render field function - * - * @since ReduxFramework 1.0.0 - */ - function __construct( $field = array(), $value = '', $parent ) { - $this->parent = $parent; - $this->field = $field; - $this->value = $value; - - if ( is_array( $this->value ) ) { - $this->value = ''; - } else { - $this->value = trim( $this->value ); - } - - if ( ! empty( $this->field['options'] ) ) { - $this->field['args'] = $this->field['options']; - unset( $this->field['options'] ); - } - - } - - /** - * Field Render Function. - * Takes the vars and outputs the HTML for the field in the settings - * - * @since ReduxFramework 1.0.0 - */ - function render() { - - if ( ! isset( $this->field['mode'] ) ) { - $this->field['mode'] = 'javascript'; - } - if ( ! isset( $this->field['theme'] ) ) { - $this->field['theme'] = 'monokai'; - } - - $params = array( - 'minLines' => 10, - 'maxLines' => 30, - ); - - if ( isset( $this->field['args'] ) && ! empty( $this->field['args'] ) && is_array( $this->field['args'] ) ) { - $params = wp_parse_args( $this->field['args'], $params ); - } - - ?> -
    - - -
    value ); ?>
    -
    - parent->args['dev_mode'] ) { - if ( ! wp_style_is( 'redux-field-ace-editor-css' ) ) { - wp_enqueue_style( - 'redux-field-ace-editor-css', - ReduxFramework::$_url . 'inc/fields/ace_editor/field_ace_editor.css', - array(), - time(), - 'all' - ); - } - } - - if ( ! wp_script_is( 'ace-editor-js' ) ) { - Redux_CDN::enqueue_script( - 'ace-editor-js', - '//cdn.jsdelivr.net/ace/1.1.9/min/ace.js', - array( 'jquery' ), - '1.1.9', - true - ); - } - - if ( ! wp_script_is( 'redux-field-ace-editor-js' ) ) { - wp_enqueue_script( - 'redux-field-ace-editor-js', - ReduxFramework::$_url . 'inc/fields/ace_editor/field_ace_editor' . Redux_Functions::isMin() . '.js', - array( 'jquery', 'ace-editor-js', 'redux-js' ), - time(), - true - ); - } - } - } - } \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/ace_editor/field_ace_editor.scss b/library/admin/ReduxCore/inc/fields/ace_editor/field_ace_editor.scss deleted file mode 100644 index 77d30371..00000000 --- a/library/admin/ReduxCore/inc/fields/ace_editor/field_ace_editor.scss +++ /dev/null @@ -1,16 +0,0 @@ -.redux-container-ace_editor { - .ace-wrapper { - position: static; - } - - .ace_editor { - height: 200px; - -webkit-border-radius: 3px; - -moz-border-radius: 3px; - border-radius: 3px; - } - - .ace_gutter { - z-index: 1 !important; - } -} \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/background/field_background.css b/library/admin/ReduxCore/inc/fields/background/field_background.css deleted file mode 100644 index 84816a57..00000000 --- a/library/admin/ReduxCore/inc/fields/background/field_background.css +++ /dev/null @@ -1 +0,0 @@ -.redux-main .redux-container-background .redux-background-position,.redux-main .redux-container-background .redux-background-position select,.redux-main .redux-container-background .redux-background-attachment,.redux-main .redux-container-background .redux-background-attachment select,.redux-main .redux-container-background .redux-background-clip,.redux-main .redux-container-background .redux-background-clip select,.redux-main .redux-container-background .redux-background-origin,.redux-main .redux-container-background .redux-background-origin select,.redux-main .redux-container-background .redux-background-size,.redux-main .redux-container-background .redux-background-size select,.redux-main .redux-container-background .redux-background-repeat,.redux-main .redux-container-background .redux-background-repeat select{width:200px !important;margin-right:10px;margin-bottom:7px}.redux-main .redux-container-background .background-preview{display:block;width:100%;margin:5px 0 10px;border:1px dotted lightgray}.redux-main .redux-container-background .select2-container{margin-right:10px;margin-bottom:10px}.redux-main .redux-container-background .wp-picker-container{margin-bottom:10px}.redux-main .redux-container-background .upload{width:100%;margin-bottom:8px}.redux-main .redux-container-select li.ui-state-highlight{height:20px;margin-top:2px;margin-left:5px;width:64px;margin-bottom:0}.wp-customizer .redux-container-background .redux-background-position,.wp-customizer .redux-container-background .redux-background-position select,.wp-customizer .redux-container-background .redux-background-attachment,.wp-customizer .redux-container-background .redux-background-attachment select,.wp-customizer .redux-container-background .redux-background-clip,.wp-customizer .redux-container-background .redux-background-clip select,.wp-customizer .redux-container-background .redux-background-origin,.wp-customizer .redux-container-background .redux-background-origin select,.wp-customizer .redux-container-background .redux-background-size,.wp-customizer .redux-container-background .redux-background-size select,.wp-customizer .redux-container-background .redux-background-repeat,.wp-customizer .redux-container-background .redux-background-repeat select{width:100% !important} diff --git a/library/admin/ReduxCore/inc/fields/background/field_background.js b/library/admin/ReduxCore/inc/fields/background/field_background.js deleted file mode 100644 index eb922f88..00000000 --- a/library/admin/ReduxCore/inc/fields/background/field_background.js +++ /dev/null @@ -1,324 +0,0 @@ -/** - * Redux Background - * Dependencies : jquery, wp media uploader - * Feature added by : Dovy Paukstys - * Date : 07 Jan 2014 - */ - -/*global redux_change, wp, redux*/ - -(function( $ ) { - "use strict"; - - redux.field_objects = redux.field_objects || {}; - redux.field_objects.background = redux.field_objects.background || {}; - - redux.field_objects.background.init = function( selector ) { - if ( !selector ) { - selector = $( document ).find( ".redux-group-tab:visible" ).find( '.redux-container-background:visible' ); - } - - $( selector ).each( - function() { - var el = $( this ); - var parent = el; - if ( !el.hasClass( 'redux-field-container' ) ) { - parent = el.parents( '.redux-field-container:first' ); - } - - if ( parent.is( ":hidden" ) ) { // Skip hidden fields - return; - } - - if ( parent.hasClass( 'redux-field-init' ) ) { - parent.removeClass( 'redux-field-init' ); - } else { - return; - } - // Remove the image button - el.find( '.redux-remove-background' ).unbind( 'click' ).on( - 'click', function( e ) { - e.preventDefault(); - redux.field_objects.background.removeImage( $( this ).parents( '.redux-container-background:first' ) ); - return false; - } - ); - - // Upload media button - el.find( '.redux-background-upload' ).unbind().on( - 'click', function( event ) { - redux.field_objects.background.addImage( - event, $( this ).parents( '.redux-container-background:first' ) - ); - } - ); - - el.find( '.redux-background-input' ).on( - 'change', function() { - redux.field_objects.background.preview( $( this ) ); - } - ); - - el.find( '.redux-color' ).wpColorPicker( - { - change: function( e, ui ) { - $( this ).val( ui.color.toString() ); - redux_change( $( this ) ); - $( '#' + e.target.id + '-transparency' ).removeAttr( 'checked' ); - redux.field_objects.background.preview( $( this ) ); - }, - - clear: function( e, ui ) { - $( this ).val( ui.color.toString() ); - redux_change( $( this ).parent().find( '.redux-color-init' ) ); - redux.field_objects.background.preview( $( this ) ); - } - } - ); - - // Replace and validate field on blur - el.find( '.redux-color' ).on( - 'blur', function() { - var value = $( this ).val(); - var id = '#' + $( this ).attr( 'id' ); - - if ( value === "transparent" ) { - $( this ).parent().parent().find( '.wp-color-result' ).css( - 'background-color', 'transparent' - ); - - el.find( id + '-transparency' ).attr( 'checked', 'checked' ); - } else { - if ( colorValidate( this ) === value ) { - if ( value.indexOf( "#" ) !== 0 ) { - $( this ).val( $( this ).data( 'oldcolor' ) ); - } - } - - el.find( id + '-transparency' ).removeAttr( 'checked' ); - } - } - ); - - el.find( '.redux-color' ).on( - 'focus', function() { - $( this ).data( 'oldcolor', $( this ).val() ); - } - ); - - el.find( '.redux-color' ).on( - 'keyup', function() { - var value = $( this ).val(); - var color = colorValidate( this ); - var id = '#' + $( this ).attr( 'id' ); - - if ( value === "transparent" ) { - $( this ).parent().parent().find( '.wp-color-result' ).css( - 'background-color', 'transparent' - ); - el.find( id + '-transparency' ).attr( 'checked', 'checked' ); - } else { - el.find( id + '-transparency' ).removeAttr( 'checked' ); - - if ( color && color !== $( this ).val() ) { - $( this ).val( color ); - } - } - } - ); - - // When transparency checkbox is clicked - el.find( '.color-transparency' ).on( - 'click', function() { - if ( $( this ).is( ":checked" ) ) { - el.find( '.redux-saved-color' ).val( $( '#' + $( this ).data( 'id' ) ).val() ); - el.find( '#' + $( this ).data( 'id' ) ).val( 'transparent' ); - el.find( '#' + $( this ).data( 'id' ) ).parent().parent().find( '.wp-color-result' ).css( - 'background-color', 'transparent' - ); - } else { - if ( el.find( '#' + $( this ).data( 'id' ) ).val() === 'transparent' ) { - var prevColor = $( '.redux-saved-color' ).val(); - - if ( prevColor === '' ) { - prevColor = $( '#' + $( this ).data( 'id' ) ).data( 'default-color' ); - } - - el.find( '#' + $( this ).data( 'id' ) ).parent().parent().find( '.wp-color-result' ).css( - 'background-color', prevColor - ); - el.find( '#' + $( this ).data( 'id' ) ).val( prevColor ); - } - } - redux.field_objects.background.preview( $( this ) ); - redux_change( $( this ) ); - } - ); - - var default_params = { - width: 'resolve', - triggerChange: true, - allowClear: true - }; - - var select2_handle = el.find( '.select2_params' ); - if ( select2_handle.size() > 0 ) { - var select2_params = select2_handle.val(); - - select2_params = JSON.parse( select2_params ); - default_params = $.extend( {}, default_params, select2_params ); - } - - el.find( " .redux-background-repeat, .redux-background-clip, .redux-background-origin, .redux-background-size, .redux-background-attachment, .redux-background-position" ).select2( default_params ); - - } - ); - }; - - // Update the background preview - redux.field_objects.background.preview = function( selector ) { - var parent = $( selector ).parents( '.redux-container-background:first' ); - var preview = $( parent ).find( '.background-preview' ); - - if ( !preview ) { // No preview present - return; - } - var hide = true; - - var css = 'height:' + preview.height() + 'px;'; - $( parent ).find( '.redux-background-input' ).each( - function() { - var data = $( this ).serializeArray(); - data = data[0]; - if ( data && data.name.indexOf( '[background-' ) != -1 ) { - if ( data.value !== "" ) { - hide = false; - data.name = data.name.split( '[background-' ); - data.name = 'background-' + data.name[1].replace( ']', '' ); - if ( data.name == "background-image" ) { - css += data.name + ':url("' + data.value + '");'; - } else { - css += data.name + ':' + data.value + ';'; - } - } - } - } - ); - if ( !hide ) { - preview.attr( 'style', css ).fadeIn(); - } else { - preview.slideUp(); - } - - - }; - - // Add a file via the wp.media function - redux.field_objects.background.addImage = function( event, selector ) { - event.preventDefault(); - - var frame; - var jQueryel = $( this ); - - // If the media frame already exists, reopen it. - if ( frame ) { - frame.open(); - return; - } - - // Create the media frame. - frame = wp.media( - { - multiple: false, - library: { - //type: 'image' //Only allow images - }, - // Set the title of the modal. - title: jQueryel.data( 'choose' ), - // Customize the submit button. - button: { - // Set the text of the button. - text: jQueryel.data( 'update' ) - // Tell the button not to close the modal, since we're - // going to refresh the page when the image is selected. - - } - } - ); - - // When an image is selected, run a callback. - frame.on( - 'select', function() { - // Grab the selected attachment. - var attachment = frame.state().get( 'selection' ).first(); - frame.close(); - - //console.log(attachment.attributes.type); - - if ( attachment.attributes.type !== "image" ) { - return; - } - - selector.find( '.upload' ).val( attachment.attributes.url ); - selector.find( '.upload-id' ).val( attachment.attributes.id ); - selector.find( '.upload-height' ).val( attachment.attributes.height ); - selector.find( '.upload-width' ).val( attachment.attributes.width ); - redux_change( $( selector ).find( '.upload-id' ) ); - var thumbSrc = attachment.attributes.url; - if ( typeof attachment.attributes.sizes !== 'undefined' && typeof attachment.attributes.sizes.thumbnail !== 'undefined' ) { - thumbSrc = attachment.attributes.sizes.thumbnail.url; - } else if ( typeof attachment.attributes.sizes !== 'undefined' ) { - var height = attachment.attributes.height; - for ( var key in attachment.attributes.sizes ) { - var object = attachment.attributes.sizes[key]; - if ( object.height < height ) { - height = object.height; - thumbSrc = object.url; - } - } - } else { - thumbSrc = attachment.attributes.icon; - } - selector.find( '.upload-thumbnail' ).val( thumbSrc ); - if ( !selector.find( '.upload' ).hasClass( 'noPreview' ) ) { - selector.find( '.screenshot' ).empty().hide().append( '' ).slideDown( 'fast' ); - } - - selector.find( '.redux-remove-background' ).removeClass( 'hide' );//show "Remove" button - selector.find( '.redux-background-input-properties' ).slideDown(); - redux.field_objects.background.preview( selector.find( '.upload' ) ); - } - ); - - // Finally, open the modal. - frame.open(); - }; - - // Update the background preview - redux.field_objects.background.removeImage = function( selector ) { - - // This shouldn't have been run... - if ( !selector.find( '.redux-remove-background' ).addClass( 'hide' ) ) { - return; - } - selector.find( '.redux-remove-background' ).addClass( 'hide' ); //hide "Remove" button - - selector.find( '.upload' ).val( '' ); - selector.find( '.upload-id' ).val( '' ); - selector.find( '.upload-height' ).val( '' ); - selector.find( '.upload-width' ).val( '' ); - redux_change( $( selector ).find( '.upload-id' ) ); - selector.find( '.redux-background-input-properties' ).hide(); - var screenshot = selector.find( '.screenshot' ); - - // Hide the screenshot - screenshot.slideUp(); - - selector.find( '.remove-file' ).unbind(); - // We don't display the upload button if .upload-notice is present - // This means the user doesn't have the WordPress 3.5 Media Library Support - if ( $( '.section-upload .upload-notice' ).length > 0 ) { - $( '.redux-background-upload' ).remove(); - } - }; -})( jQuery ); diff --git a/library/admin/ReduxCore/inc/fields/background/field_background.min.js b/library/admin/ReduxCore/inc/fields/background/field_background.min.js deleted file mode 100644 index 379eabd6..00000000 --- a/library/admin/ReduxCore/inc/fields/background/field_background.min.js +++ /dev/null @@ -1 +0,0 @@ -!function(a){"use strict";redux.field_objects=redux.field_objects||{},redux.field_objects.background=redux.field_objects.background||{},redux.field_objects.background.init=function(b){b||(b=a(document).find(".redux-group-tab:visible").find(".redux-container-background:visible")),a(b).each(function(){var b=a(this),c=b;if(b.hasClass("redux-field-container")||(c=b.parents(".redux-field-container:first")),!c.is(":hidden")&&c.hasClass("redux-field-init")){c.removeClass("redux-field-init"),b.find(".redux-remove-background").unbind("click").on("click",function(b){return b.preventDefault(),redux.field_objects.background.removeImage(a(this).parents(".redux-container-background:first")),!1}),b.find(".redux-background-upload").unbind().on("click",function(b){redux.field_objects.background.addImage(b,a(this).parents(".redux-container-background:first"))}),b.find(".redux-background-input").on("change",function(){redux.field_objects.background.preview(a(this))}),b.find(".redux-color").wpColorPicker({change:function(b,c){a(this).val(c.color.toString()),redux_change(a(this)),a("#"+b.target.id+"-transparency").removeAttr("checked"),redux.field_objects.background.preview(a(this))},clear:function(b,c){a(this).val(c.color.toString()),redux_change(a(this).parent().find(".redux-color-init")),redux.field_objects.background.preview(a(this))}}),b.find(".redux-color").on("blur",function(){var c=a(this).val(),d="#"+a(this).attr("id");"transparent"===c?(a(this).parent().parent().find(".wp-color-result").css("background-color","transparent"),b.find(d+"-transparency").attr("checked","checked")):(colorValidate(this)===c&&0!==c.indexOf("#")&&a(this).val(a(this).data("oldcolor")),b.find(d+"-transparency").removeAttr("checked"))}),b.find(".redux-color").on("focus",function(){a(this).data("oldcolor",a(this).val())}),b.find(".redux-color").on("keyup",function(){var c=a(this).val(),d=colorValidate(this),e="#"+a(this).attr("id");"transparent"===c?(a(this).parent().parent().find(".wp-color-result").css("background-color","transparent"),b.find(e+"-transparency").attr("checked","checked")):(b.find(e+"-transparency").removeAttr("checked"),d&&d!==a(this).val()&&a(this).val(d))}),b.find(".color-transparency").on("click",function(){if(a(this).is(":checked"))b.find(".redux-saved-color").val(a("#"+a(this).data("id")).val()),b.find("#"+a(this).data("id")).val("transparent"),b.find("#"+a(this).data("id")).parent().parent().find(".wp-color-result").css("background-color","transparent");else if("transparent"===b.find("#"+a(this).data("id")).val()){var c=a(".redux-saved-color").val();""===c&&(c=a("#"+a(this).data("id")).data("default-color")),b.find("#"+a(this).data("id")).parent().parent().find(".wp-color-result").css("background-color",c),b.find("#"+a(this).data("id")).val(c)}redux.field_objects.background.preview(a(this)),redux_change(a(this))});var d={width:"resolve",triggerChange:!0,allowClear:!0},e=b.find(".select2_params");if(e.size()>0){var f=e.val();f=JSON.parse(f),d=a.extend({},d,f)}b.find(" .redux-background-repeat, .redux-background-clip, .redux-background-origin, .redux-background-size, .redux-background-attachment, .redux-background-position").select2(d)}})},redux.field_objects.background.preview=function(b){var c=a(b).parents(".redux-container-background:first"),d=a(c).find(".background-preview");if(d){var e=!0,f="height:"+d.height()+"px;";a(c).find(".redux-background-input").each(function(){var b=a(this).serializeArray();b=b[0],b&&-1!=b.name.indexOf("[background-")&&""!==b.value&&(e=!1,b.name=b.name.split("[background-"),b.name="background-"+b.name[1].replace("]",""),f+="background-image"==b.name?b.name+':url("'+b.value+'");':b.name+":"+b.value+";")}),e?d.slideUp():d.attr("style",f).fadeIn()}},redux.field_objects.background.addImage=function(b,c){b.preventDefault();var d,e=a(this);return d?void d.open():(d=wp.media({multiple:!1,library:{},title:e.data("choose"),button:{text:e.data("update")}}),d.on("select",function(){var b=d.state().get("selection").first();if(d.close(),"image"===b.attributes.type){c.find(".upload").val(b.attributes.url),c.find(".upload-id").val(b.attributes.id),c.find(".upload-height").val(b.attributes.height),c.find(".upload-width").val(b.attributes.width),redux_change(a(c).find(".upload-id"));var e=b.attributes.url;if("undefined"!=typeof b.attributes.sizes&&"undefined"!=typeof b.attributes.sizes.thumbnail)e=b.attributes.sizes.thumbnail.url;else if("undefined"!=typeof b.attributes.sizes){var f=b.attributes.height;for(var g in b.attributes.sizes){var h=b.attributes.sizes[g];h.height').slideDown("fast"),c.find(".redux-remove-background").removeClass("hide"),c.find(".redux-background-input-properties").slideDown(),redux.field_objects.background.preview(c.find(".upload"))}}),void d.open())},redux.field_objects.background.removeImage=function(b){if(b.find(".redux-remove-background").addClass("hide")){b.find(".redux-remove-background").addClass("hide"),b.find(".upload").val(""),b.find(".upload-id").val(""),b.find(".upload-height").val(""),b.find(".upload-width").val(""),redux_change(a(b).find(".upload-id")),b.find(".redux-background-input-properties").hide();var c=b.find(".screenshot");c.slideUp(),b.find(".remove-file").unbind(),a(".section-upload .upload-notice").length>0&&a(".redux-background-upload").remove()}}}(jQuery); \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/background/field_background.php b/library/admin/ReduxCore/inc/fields/background/field_background.php deleted file mode 100644 index 74efb684..00000000 --- a/library/admin/ReduxCore/inc/fields/background/field_background.php +++ /dev/null @@ -1,430 +0,0 @@ -. - * - * @package ReduxFramework - * @subpackage Field_Background - * @author Dovy Paukstys - * @version 3.1.5 - */ -// Exit if accessed directly - if ( ! defined( 'ABSPATH' ) ) { - exit; - } - -// Don't duplicate me! - if ( ! class_exists( 'ReduxFramework_background' ) ) { - - /** - * Main ReduxFramework_background class - * - * @since 3.1.5 - */ - class ReduxFramework_background { - - /** - * Field Constructor. - * Required - must call the parent constructor, then assign field and value to vars, and obviously call the render field function - * - * @since 3.1.5 - * @access public - * @return void - */ - function __construct( $field = array(), $value = '', $parent ) { - - $this->parent = $parent; - $this->field = $field; - $this->value = $value; - } - - /** - * Field Render Function. - * Takes the vars and outputs the HTML for the field in the settings - * - * @since 1.0.0 - * @access public - * @return void - */ - public function render() { - - $defaults = array( - 'background-color' => true, - 'background-repeat' => true, - 'background-attachment' => true, - 'background-position' => true, - 'background-image' => true, - 'background-gradient' => false, - 'background-clip' => false, - 'background-origin' => false, - 'background-size' => true, - 'preview_media' => false, - 'preview' => true, - 'preview_height' => '200px', - 'transparent' => true, - ); - - $this->field = wp_parse_args( $this->field, $defaults ); - - // No errors please - $defaults = array( - 'background-color' => '', - 'background-repeat' => '', - 'background-attachment' => '', - 'background-position' => '', - 'background-image' => '', - 'background-clip' => '', - 'background-origin' => '', - 'background-size' => '', - 'media' => array(), - ); - - $this->value = wp_parse_args( $this->value, $defaults ); - - $defaults = array( - 'id' => '', - 'width' => '', - 'height' => '', - 'thumbnail' => '', - ); - - $this->value['media'] = wp_parse_args( $this->value['media'], $defaults ); - - // select2 args - if ( isset( $this->field['select2'] ) ) { // if there are any let's pass them to js - $select2_params = json_encode( $this->field['select2'] ); - $select2_params = htmlspecialchars( $select2_params, ENT_QUOTES ); - - echo ''; - } - - if ( $this->field['background-color'] === true ) { - - if ( isset( $this->value['color'] ) && empty( $this->value['background-color'] ) ) { - $this->value['background-color'] = $this->value['color']; - } - - echo ''; - echo ''; - - if ( ! isset( $this->field['transparent'] ) || $this->field['transparent'] !== false ) { - $tChecked = ""; - if ( $this->value['background-color'] == "transparent" ) { - $tChecked = ' checked="checked"'; - } - echo ''; - } - - if ( $this->field['background-repeat'] === true || $this->field['background-position'] === true || $this->field['background-attachment'] === true ) { - echo '
    '; - } - } - - - if ( $this->field['background-repeat'] === true ) { - $array = array( - 'no-repeat' => 'No Repeat', - 'repeat' => 'Repeat All', - 'repeat-x' => 'Repeat Horizontally', - 'repeat-y' => 'Repeat Vertically', - 'inherit' => 'Inherit', - ); - echo ''; - } - - if ( $this->field['background-clip'] === true ) { - $array = array( - 'inherit' => 'Inherit', - 'border-box' => 'Border Box', - 'content-box' => 'Content Box', - 'padding-box' => 'Padding Box', - ); - echo ''; - } - - if ( $this->field['background-origin'] === true ) { - $array = array( - 'inherit' => 'Inherit', - 'border-box' => 'Border Box', - 'content-box' => 'Content Box', - 'padding-box' => 'Padding Box', - ); - echo ''; - } - - if ( $this->field['background-size'] === true ) { - $array = array( - 'inherit' => 'Inherit', - 'cover' => 'Cover', - 'contain' => 'Contain', - ); - echo ''; - } - - if ( $this->field['background-attachment'] === true ) { - $array = array( - 'fixed' => 'Fixed', - 'scroll' => 'Scroll', - 'inherit' => 'Inherit', - ); - echo ''; - } - - if ( $this->field['background-position'] === true ) { - $array = array( - 'left top' => 'Left Top', - 'left center' => 'Left center', - 'left bottom' => 'Left Bottom', - 'center top' => 'Center Top', - 'center center' => 'Center Center', - 'center bottom' => 'Center Bottom', - 'right top' => 'Right Top', - 'right center' => 'Right center', - 'right bottom' => 'Right Bottom', - ); - echo ''; - } - - if ( $this->field['background-image'] === true ) { - echo '
    '; - - if ( empty( $this->value ) && ! empty( $this->field['default'] ) ) { // If there are standard values and value is empty - if ( is_array( $this->field['default'] ) ) { - if ( ! empty( $this->field['default']['media']['id'] ) ) { - $this->value['media']['id'] = $this->field['default']['media']['id']; - } else if ( ! empty( $this->field['default']['id'] ) ) { - $this->value['media']['id'] = $this->field['default']['id']; - } - - if ( ! empty( $this->field['default']['url'] ) ) { - $this->value['background-image'] = $this->field['default']['url']; - } else if ( ! empty( $this->field['default']['media']['url'] ) ) { - $this->value['background-image'] = $this->field['default']['media']['url']; - } else if ( ! empty( $this->field['default']['background-image'] ) ) { - $this->value['background-image'] = $this->field['default']['background-image']; - } - } else { - if ( is_numeric( $this->field['default'] ) ) { // Check if it's an attachment ID - $this->value['media']['id'] = $this->field['default']; - } else { // Must be a URL - $this->value['background-image'] = $this->field['default']; - } - } - } - - - if ( empty( $this->value['background-image'] ) && ! empty( $this->value['media']['id'] ) ) { - $img = wp_get_attachment_image_src( $this->value['media']['id'], 'full' ); - $this->value['background-image'] = $img[0]; - $this->value['media']['width'] = $img[1]; - $this->value['media']['height'] = $img[2]; - } - - $hide = 'hide '; - - if ( ( isset( $this->field['preview_media'] ) && $this->field['preview_media'] === false ) ) { - $this->field['class'] .= " noPreview"; - } - - if ( ( ! empty( $this->field['background-image'] ) && $this->field['background-image'] === true ) || isset( $this->field['preview'] ) && $this->field['preview'] === false ) { - $hide = ''; - } - - $placeholder = isset( $this->field['placeholder'] ) ? $this->field['placeholder'] : __( 'No media selected', 'redux-framework' ); - - echo ''; - echo ''; - echo ''; - echo ''; - echo ''; - - //Preview - $hide = ''; - - if ( ( isset( $this->field['preview_media'] ) && $this->field['preview_media'] === false ) || empty( $this->value['background-image'] ) ) { - $hide = 'hide '; - } - - if ( empty( $this->value['media']['thumbnail'] ) && ! empty( $this->value['background-image'] ) ) { // Just in case - if ( ! empty( $this->value['media']['id'] ) ) { - $image = wp_get_attachment_image_src( $this->value['media']['id'], array( - 150, - 150 - ) ); - $this->value['media']['thumbnail'] = $image[0]; - } else { - $this->value['media']['thumbnail'] = $this->value['background-image']; - } - } - - echo '
    '; - echo ''; - echo ''; - echo ''; - echo '
    '; - - //Upload controls DIV - echo '
    '; - - //If the user has WP3.5+ show upload/remove button - echo '' . __( 'Upload', 'redux-framework' ) . ''; - - $hide = ''; - if ( empty( $this->value['background-image'] ) || $this->value['background-image'] == '' ) { - $hide = ' hide'; - } - - echo '' . __( 'Remove', 'redux-framework' ) . ''; - - echo '
    '; - } - - - /** - * Preview - * */ - if ( ! isset( $this->field['preview'] ) || $this->field['preview'] !== false ): - - $css = $this->getCSS(); - if ( empty( $css ) ) { - $css = "display:none;"; - } - $css .= "height: " . $this->field['preview_height'] . ";"; - echo '

     

    '; - - endif; - } - - /** - * Enqueue Function. - * If this field requires any scripts, or css define this function and register/enqueue the scripts/css - * - * @since 1.0.0 - * @access public - * @return void - */ - public function enqueue() { - if ( function_exists( 'wp_enqueue_media' ) ) { - wp_enqueue_media(); - } else { - if (!wp_script_is ( 'media-upload' )) { - wp_enqueue_script( 'media-upload' ); - } - } - - if (!wp_style_is ( 'select2-css' )) { - wp_enqueue_style( 'select2-css' ); - } - - if (!wp_style_is ( 'wp-color-picker' )) { - wp_enqueue_style( 'wp-color-picker' ); - } - - if (!wp_script_is ( 'redux-field-background-js' )) { - wp_enqueue_script( - 'redux-field-background-js', - ReduxFramework::$_url . 'inc/fields/background/field_background' . Redux_Functions::isMin() . '.js', - array( 'jquery', 'wp-color-picker', 'select2-js', 'redux-js' ), - time(), - true - ); - } - - if ($this->parent->args['dev_mode']) { - if (!wp_style_is ( 'redux-field-background-css' )) { - wp_enqueue_style( - 'redux-field-background-css', - ReduxFramework::$_url . 'inc/fields/background/field_background.css', - array(), - time(), - 'all' - ); - } - - if (!wp_style_is ( 'redux-color-picker-css' )) { - wp_enqueue_style( 'redux-color-picker-css' ); - } - } - } - - public static function getCSS( $value = array() ) { - - $css = ''; - - if ( ! empty( $value ) && is_array( $value ) ) { - foreach ( $value as $key => $value ) { - if ( ! empty( $value ) && $key != "media" ) { - if ( $key == "background-image" ) { - $css .= $key . ":url('" . $value . "');"; - } else { - $css .= $key . ":" . $value . ";"; - } - } - } - } - - return $css; - } - - public function output() { - $style = $this->getCSS( $this->value ); - - if ( ! empty( $style ) ) { - - if ( ! empty( $this->field['output'] ) && is_array( $this->field['output'] ) ) { - $keys = implode( ",", $this->field['output'] ); - $this->parent->outputCSS .= $keys . "{" . $style . '}'; - } - - if ( ! empty( $this->field['compiler'] ) && is_array( $this->field['compiler'] ) ) { - $keys = implode( ",", $this->field['compiler'] ); - $this->parent->compilerCSS .= $keys . "{" . $style . '}'; - } - } - } - } - } diff --git a/library/admin/ReduxCore/inc/fields/background/field_background.scss b/library/admin/ReduxCore/inc/fields/background/field_background.scss deleted file mode 100644 index 634f0f7c..00000000 --- a/library/admin/ReduxCore/inc/fields/background/field_background.scss +++ /dev/null @@ -1,59 +0,0 @@ -.redux-main { - .redux-container-background { - .redux-background-position, - .redux-background-position select, - .redux-background-attachment, - .redux-background-attachment select, - .redux-background-clip, - .redux-background-clip select, - .redux-background-origin, - .redux-background-origin select, - .redux-background-size, - .redux-background-size select, - .redux-background-repeat, - .redux-background-repeat select { - width:200px !important; - margin-right: 10px; - margin-bottom: 7px; - } - - .background-preview { - display:block; - width: 100%; - margin: 5px 0 10px; - border:1px dotted lightgray; - } - - .select2-container { - margin-right: 10px; - margin-bottom: 10px; - } - - .wp-picker-container { - margin-bottom: 10px; - } - - .upload { - width: 100%; - margin-bottom: 8px; - } - } - - .redux-container-select { - li.ui-state-highlight { - height: 20px; - margin-top:2px; - margin-left: 5px; - width: 64px; - margin-bottom: 0; - } - } -} - -.wp-customizer { - .redux-container-background { - .redux-background-position, .redux-background-position select, .redux-background-attachment, .redux-background-attachment select, .redux-background-clip, .redux-background-clip select, .redux-background-origin, .redux-background-origin select, .redux-background-size, .redux-background-size select, .redux-background-repeat, .redux-background-repeat select { - width: 100% !important; - } - } -} diff --git a/library/admin/ReduxCore/inc/fields/border/field_border.css b/library/admin/ReduxCore/inc/fields/border/field_border.css deleted file mode 100644 index dd931cee..00000000 --- a/library/admin/ReduxCore/inc/fields/border/field_border.css +++ /dev/null @@ -1 +0,0 @@ -.redux-container-border .select2-container{float:left;display:block;margin-right:10px}.redux-container-border .select_wrapper{float:left;width:inherit}.redux-container-border .select_wrapper select{width:80px;float:left}.redux-container-border .field-border-input{margin-right:10px;margin-bottom:7px}.redux-container-border .wp-picker-container{margin-top:2px}@media screen and (max-width: 782px){.redux-container-border .field-border-input input{display:inline-block !important;width:100px !important}.redux-container-border .field-border-input .add-on{padding:7px 4px;font-size:16px;line-height:1.5}.redux-container-border .select_wrapper{margin-top:6px}} diff --git a/library/admin/ReduxCore/inc/fields/border/field_border.js b/library/admin/ReduxCore/inc/fields/border/field_border.js deleted file mode 100644 index 2f7f7c87..00000000 --- a/library/admin/ReduxCore/inc/fields/border/field_border.js +++ /dev/null @@ -1,137 +0,0 @@ -/* - Field Border (border) - */ - -/*global redux_change, wp, redux*/ - -(function( $ ) { - "use strict"; - - redux.field_objects = redux.field_objects || {}; - redux.field_objects.border = redux.field_objects.border || {}; - - $( document ).ready( - function() { - - } - ); - - redux.field_objects.border.init = function( selector ) { - if ( !selector ) { - selector = $( document ).find( ".redux-group-tab:visible" ).find( '.redux-container-border:visible' ); - } - - $( selector ).each( - function() { - var el = $( this ); - var parent = el; - - if ( !el.hasClass( 'redux-field-container' ) ) { - parent = el.parents( '.redux-field-container:first' ); - } - if ( parent.is( ":hidden" ) ) { // Skip hidden fields - return; - } - if ( parent.hasClass( 'redux-field-init' ) ) { - parent.removeClass( 'redux-field-init' ); - } else { - return; - } - el.find( ".redux-border-top, .redux-border-right, .redux-border-bottom, .redux-border-left, .redux-border-all" ).numeric( - { - allowMinus: false - } - ); - - var default_params = { - triggerChange: true, - allowClear: true - }; - - var select2_handle = el.find( '.redux-container-border' ).find( '.select2_params' ); - - if ( select2_handle.size() > 0 ) { - var select2_params = select2_handle.val(); - - select2_params = JSON.parse( select2_params ); - default_params = $.extend( {}, default_params, select2_params ); - } - - el.find( ".redux-border-style" ).select2( default_params ); - - el.find( '.redux-border-input' ).on( - 'change', function() { - var units = $( this ).parents( '.redux-field:first' ).find( '.field-units' ).val(); - if ( $( this ).parents( '.redux-field:first' ).find( '.redux-border-units' ).length !== 0 ) { - units = $( this ).parents( '.redux-field:first' ).find( '.redux-border-units option:selected' ).val(); - } - var value = $( this ).val(); - if ( typeof units !== 'undefined' && value ) { - value += units; - } - if ( $( this ).hasClass( 'redux-border-all' ) ) { - $( this ).parents( '.redux-field:first' ).find( '.redux-border-value' ).each( - function() { - $( this ).val( value ); - } - ); - } else { - $( '#' + $( this ).attr( 'rel' ) ).val( value ); - } - } - ); - - el.find( '.redux-border-units' ).on( - 'change', function() { - $( this ).parents( '.redux-field:first' ).find( '.redux-border-input' ).change(); - } - ); - - el.find( '.redux-color-init' ).wpColorPicker( - { - change: function( e, ui ) { - $( this ).val( ui.color.toString() ); - redux_change( $( this ) ); - el.find( '#' + e.target.getAttribute( 'data-id' ) + '-transparency' ).removeAttr( 'checked' ); - }, - - clear: function( e, ui ) { - $( this ).val( ui.color.toString() ); - redux_change( $( this ).parent().find( '.redux-color-init' ) ); - } - } - ); - - el.find( '.redux-color' ).on( - 'keyup', function() { - var color = colorValidate( this ); - - if ( color && color !== $( this ).val() ) { - $( this ).val( color ); - } - } - ); - - // Replace and validate field on blur - el.find( '.redux-color' ).on( - 'blur', function() { - var value = $( this ).val(); - - if ( colorValidate( this ) === value ) { - if ( value.indexOf( "#" ) !== 0 ) { - $( this ).val( $( this ).data( 'oldcolor' ) ); - } - } - } - ); - - // Store the old valid color on keydown - el.find( '.redux-color' ).on( - 'keydown', function() { - $( this ).data( 'oldkeypress', $( this ).val() ); - } - ); - } - ); - }; -})( jQuery ); \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/border/field_border.min.js b/library/admin/ReduxCore/inc/fields/border/field_border.min.js deleted file mode 100644 index 138e102d..00000000 --- a/library/admin/ReduxCore/inc/fields/border/field_border.min.js +++ /dev/null @@ -1 +0,0 @@ -!function(a){"use strict";redux.field_objects=redux.field_objects||{},redux.field_objects.border=redux.field_objects.border||{},a(document).ready(function(){}),redux.field_objects.border.init=function(b){b||(b=a(document).find(".redux-group-tab:visible").find(".redux-container-border:visible")),a(b).each(function(){var b=a(this),c=b;if(b.hasClass("redux-field-container")||(c=b.parents(".redux-field-container:first")),!c.is(":hidden")&&c.hasClass("redux-field-init")){c.removeClass("redux-field-init"),b.find(".redux-border-top, .redux-border-right, .redux-border-bottom, .redux-border-left, .redux-border-all").numeric({allowMinus:!1});var d={triggerChange:!0,allowClear:!0},e=b.find(".redux-container-border").find(".select2_params");if(e.size()>0){var f=e.val();f=JSON.parse(f),d=a.extend({},d,f)}b.find(".redux-border-style").select2(d),b.find(".redux-border-input").on("change",function(){var b=a(this).parents(".redux-field:first").find(".field-units").val();0!==a(this).parents(".redux-field:first").find(".redux-border-units").length&&(b=a(this).parents(".redux-field:first").find(".redux-border-units option:selected").val());var c=a(this).val();"undefined"!=typeof b&&c&&(c+=b),a(this).hasClass("redux-border-all")?a(this).parents(".redux-field:first").find(".redux-border-value").each(function(){a(this).val(c)}):a("#"+a(this).attr("rel")).val(c)}),b.find(".redux-border-units").on("change",function(){a(this).parents(".redux-field:first").find(".redux-border-input").change()}),b.find(".redux-color-init").wpColorPicker({change:function(c,d){a(this).val(d.color.toString()),redux_change(a(this)),b.find("#"+c.target.getAttribute("data-id")+"-transparency").removeAttr("checked")},clear:function(b,c){a(this).val(c.color.toString()),redux_change(a(this).parent().find(".redux-color-init"))}}),b.find(".redux-color").on("keyup",function(){var b=colorValidate(this);b&&b!==a(this).val()&&a(this).val(b)}),b.find(".redux-color").on("blur",function(){var b=a(this).val();colorValidate(this)===b&&0!==b.indexOf("#")&&a(this).val(a(this).data("oldcolor"))}),b.find(".redux-color").on("keydown",function(){a(this).data("oldkeypress",a(this).val())})}})}}(jQuery); \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/border/field_border.php b/library/admin/ReduxCore/inc/fields/border/field_border.php deleted file mode 100644 index 2cfa12c5..00000000 --- a/library/admin/ReduxCore/inc/fields/border/field_border.php +++ /dev/null @@ -1,313 +0,0 @@ -. - * - * @package Redux_Field - * @subpackage Border - * @version 3.0.0 - */ - -// Exit if accessed directly -if ( ! defined( 'ABSPATH' ) ) { - exit; -} - -// Don't duplicate me! -if ( ! class_exists( 'ReduxFramework_border' ) ) { - - class ReduxFramework_border { - - /** - * Field Constructor. - * Required - must call the parent constructor, then assign field and value to vars, and obviously call the render field function - * - * @since ReduxFramework 1.0.0 - */ - function __construct( $field = array(), $value = '', $parent ) { - - $this->parent = $parent; - $this->field = $field; - $this->value = $value; - } //function - - private function stripAlphas($s) { - - // Regex is our friend. THERE ARE FOUR LIGHTS!! - return preg_replace('/[^\d.-]/', '', $s); - } - - /** - * Field Render Function. - * Takes the vars and outputs the HTML for the field in the settings - * - * @since ReduxFramework 1.0.0 - */ - function render() { - - // No errors please - $defaults = array( - 'top' => true, - 'bottom' => true, - 'all' => true, - 'style' => true, - 'color' => true, - 'left' => true, - 'right' => true, - ); - - $this->field = wp_parse_args( $this->field, $defaults ); - - $defaults = array( - 'top' => '', - 'right' => '', - 'bottom' => '', - 'left' => '', - 'color' => '', - 'style' => '', - ); - - $this->value = wp_parse_args( $this->value, $defaults ); - - $value = array( - 'top' => isset( $this->value['border-top'] ) ? filter_var( $this->value['border-top'], FILTER_SANITIZE_NUMBER_FLOAT, FILTER_FLAG_ALLOW_FRACTION ) : filter_var( $this->value['top'], FILTER_SANITIZE_NUMBER_FLOAT, FILTER_FLAG_ALLOW_FRACTION ), - 'right' => isset( $this->value['border-right'] ) ? filter_var( $this->value['border-right'], FILTER_SANITIZE_NUMBER_FLOAT, FILTER_FLAG_ALLOW_FRACTION ) : filter_var( $this->value['right'], FILTER_SANITIZE_NUMBER_FLOAT, FILTER_FLAG_ALLOW_FRACTION ), - 'bottom' => isset( $this->value['border-bottom'] ) ? filter_var( $this->value['border-bottom'], FILTER_SANITIZE_NUMBER_FLOAT, FILTER_FLAG_ALLOW_FRACTION ) : filter_var( $this->value['bottom'], FILTER_SANITIZE_NUMBER_FLOAT, FILTER_FLAG_ALLOW_FRACTION ), - 'left' => isset( $this->value['border-left'] ) ? filter_var( $this->value['border-left'], FILTER_SANITIZE_NUMBER_FLOAT, FILTER_FLAG_ALLOW_FRACTION ) : filter_var( $this->value['left'], FILTER_SANITIZE_NUMBER_FLOAT, FILTER_FLAG_ALLOW_FRACTION ), - 'color' => isset( $this->value['border-color'] ) ? $this->value['border-color'] : $this->value['color'], - 'style' => isset( $this->value['border-style'] ) ? $this->value['border-style'] : $this->value['style'] - ); - - if ( ( isset( $this->value['width'] ) || isset( $this->value['border-width'] ) ) ) { - if ( isset( $this->value['border-width'] ) && ! empty( $this->value['border-width'] ) ) { - $this->value['width'] = $this->value['border-width']; - } - - $this->value['width'] = $this->stripAlphas($this->value['width']); - - $value['top'] = $this->value['width']; - $value['right'] = $this->value['width']; - $value['bottom'] = $this->value['width']; - $value['left'] = $this->value['width']; - } - - $this->value = $value; - - $defaults = array( - 'top' => '', - 'right' => '', - 'bottom' => '', - 'left' => '', - ); - - $this->value = wp_parse_args( $this->value, $defaults ); - - if ( isset( $this->field['select2'] ) ) { // if there are any let's pass them to js - $select2_params = json_encode( $this->field['select2'] ); - $select2_params = htmlspecialchars( $select2_params, ENT_QUOTES ); - - echo ''; - } - - - echo ''; - - if ( isset( $this->field['all'] ) && $this->field['all'] == true ) { - echo '
    '; - } - - echo ''; - echo ''; - echo ''; - echo ''; - - if ( ! isset( $this->field['all'] ) || $this->field['all'] !== true ) { - /** - * Top - * */ - if ( $this->field['top'] === true ) { - echo '
    '; - } - - /** - * Right - * */ - if ( $this->field['right'] === true ) { - echo '
    '; - } - - /** - * Bottom - * */ - if ( $this->field['bottom'] === true ) { - echo '
    '; - } - - /** - * Left - * */ - if ( $this->field['left'] === true ) { - echo '
    '; - } - } - - /** - * Border-style - * */ - if ( $this->field['style'] != false ) { - $options = array( - 'solid' => 'Solid', - 'dashed' => 'Dashed', - 'dotted' => 'Dotted', - 'double' => "Double", - 'none' => 'None' - ); - echo ''; - } else { - echo ''; - } - - /** - * Color - * */ - if ( $this->field['color'] != false ) { - $default = isset( $this->field['default']['border-color'] ) ? $this->field['default']['border-color'] : ''; - - - if ( empty( $default ) ) { - $default = ( isset( $this->field['default']['color'] ) ) ? $this->field['default']['color'] : '#ffffff'; - } - - echo ''; - } else { - echo ''; - } - } - - //function - - /** - * Enqueue Function. - * If this field requires any scripts, or css define this function and register/enqueue the scripts/css - * - * @since ReduxFramework 1.0.0 - */ - function enqueue() { - $min = Redux_Functions::isMin(); - - if (!wp_style_is ( 'select2-css' )) { - wp_enqueue_style( 'select2-css' ); - } - - if (!wp_style_is ( 'wp-color-picker' )) { - wp_enqueue_style( 'wp-color-picker' ); - } - - if (!wp_script_is ( 'redux-field-border-js' )) { - wp_enqueue_script( - 'redux-field-border-js', - ReduxFramework::$_url . 'inc/fields/border/field_border' . $min . '.js', - array( 'jquery', 'select2-js', 'wp-color-picker', 'redux-js' ), - time(), - true - ); - } - - if ($this->parent->args['dev_mode']) { - if (!wp_style_is ( 'redux-color-picker-css' )) { - wp_enqueue_style( 'redux-color-picker-css' ); - } - - if (!wp_style_is ( 'redux-field-border-css' )) { - wp_enqueue_style( - 'redux-field-border-css', - ReduxFramework::$_url . 'inc/fields/border/field_border.css', - array(), - time(), - 'all' - ); - } - } - } //function - - public function output() { - if ( isset( $this->field['all'] ) && true == $this->field['all'] ) { - $borderWidth = isset( $this->value['border-width'] ) ? $this->value['border-width'] : '0px'; - $val = isset( $this->value['border-top'] ) ? $this->value['border-top'] : $borderWidth; - - $this->value['border-top'] = $val; - $this->value['border-bottom'] = $val; - $this->value['border-left'] = $val; - $this->value['border-right'] = $val; - } - - $cleanValue = array( - 'color' => ! empty( $this->value['border-color'] ) ? $this->value['border-color'] : 'inherit', - 'style' => ! empty( $this->value['border-style'] ) ? $this->value['border-style'] : 'inherit' - ); - - $borderWidth = '0px'; - if ( isset( $this->value['border-width'] ) ) { - $borderWidth = $this->value['border-width']; - } - - $this->field['top'] = isset( $this->field['top'] ) ? $this->field['top'] : true; - $this->field['bottom'] = isset( $this->field['bottom'] ) ? $this->field['bottom'] : true; - $this->field['left'] = isset( $this->field['left'] ) ? $this->field['left'] : true; - $this->field['right'] = isset( $this->field['right'] ) ? $this->field['right'] : true; - - if ( $this->field['top'] === true ) { - $cleanValue['top'] = ! empty( $this->value['border-top'] ) ? $this->value['border-top'] : $borderWidth; - } - - if ( $this->field['bottom'] == true ) { - $cleanValue['bottom'] = ! empty( $this->value['border-bottom'] ) ? $this->value['border-bottom'] : $borderWidth; - } - - if ( $this->field['left'] === true ) { - $cleanValue['left'] = ! empty( $this->value['border-left'] ) ? $this->value['border-left'] : $borderWidth; - } - - if ( $this->field['right'] === true ) { - $cleanValue['right'] = ! empty( $this->value['border-right'] ) ? $this->value['border-right'] : $borderWidth; - } - - $style = ""; - - //absolute, padding, margin - if ( ! isset( $this->field['all'] ) || $this->field['all'] != true ) { - foreach ( $cleanValue as $key => $value ) { - if ( $key == "color" || $key == "style" ) { - continue; - } - $style .= 'border-' . $key . ':' . $value . ' ' . $cleanValue['style'] . ' ' . $cleanValue['color'] . ';'; - } - } else { - $style .= 'border:' . $cleanValue['top'] . ' ' . $cleanValue['style'] . ' ' . $cleanValue['color'] . ';'; - } - - if ( ! empty( $this->field['output'] ) && is_array( $this->field['output'] ) ) { - $keys = implode( ",", $this->field['output'] ); - $this->parent->outputCSS .= $keys . "{" . $style . '}'; - } - - if ( ! empty( $this->field['compiler'] ) && is_array( $this->field['compiler'] ) ) { - $keys = implode( ",", $this->field['compiler'] ); - $this->parent->compilerCSS .= $keys . "{" . $style . '}'; - } - } - } //class -} \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/border/field_border.scss b/library/admin/ReduxCore/inc/fields/border/field_border.scss deleted file mode 100644 index 54e93dd0..00000000 --- a/library/admin/ReduxCore/inc/fields/border/field_border.scss +++ /dev/null @@ -1,47 +0,0 @@ -.redux-container-border { - .select2-container { - float: left; - display: block; - margin-right: 10px; - } - - .select_wrapper { - float: left; - select { - width: 80px; - float: left; - - } - width: inherit; - } - - .field-border-input { - margin-right: 10px; - margin-bottom: 7px; - } - - .wp-picker-container { - margin-top: 2px; - } -} - -@media screen and (max-width: 782px) { - .redux-container-border { - .field-border-input { - input { - display: inline-block !important; - width: 100px !important; - } - - .add-on { - padding: 7px 4px; - font-size: 16px; - line-height: 1.5; - } - } - - .select_wrapper { - margin-top: 6px; - } - } -} \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/button_set/field_button_set.js b/library/admin/ReduxCore/inc/fields/button_set/field_button_set.js deleted file mode 100644 index fdce3ae1..00000000 --- a/library/admin/ReduxCore/inc/fields/button_set/field_button_set.js +++ /dev/null @@ -1,56 +0,0 @@ -/* - Field Button Set (button_set) - */ - -/*global jQuery, document, redux*/ - -(function( $ ) { - "use strict"; - - redux.field_objects = redux.field_objects || {}; - redux.field_objects.button_set = redux.field_objects.button_set || {}; - - $( document ).ready( - function() { - //redux.field_objects.button_set.init(); - if ( $.fn.button.noConflict !== undefined ) { - var btn = $.fn.button.noConflict(); - $.fn.btn = btn; - } - } - ); - - redux.field_objects.button_set.init = function( selector ) { - if ( !selector ) { - selector = $( document ).find( ".redux-group-tab:visible" ).find( '.redux-container-button_set:visible' ); - } - - $( selector ).each( - function() { - var el = $( this ); - var parent = el; - if ( !el.hasClass( 'redux-field-container' ) ) { - parent = el.parents( '.redux-field-container:first' ); - } - if ( parent.is( ":hidden" ) ) { // Skip hidden fields - return; - } - if ( parent.hasClass( 'redux-field-init' ) ) { - parent.removeClass( 'redux-field-init' ); - } else { - return; - } - el.find( '.buttonset' ).each( - function() { - if ( $( this ).is( ':checkbox' ) ) { - $( this ).find( '.buttonset-item' ).button(); - } - - $( this ).buttonset(); - } - ); - } - ); - - }; -})( jQuery ); \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/button_set/field_button_set.min.js b/library/admin/ReduxCore/inc/fields/button_set/field_button_set.min.js deleted file mode 100644 index ca31a658..00000000 --- a/library/admin/ReduxCore/inc/fields/button_set/field_button_set.min.js +++ /dev/null @@ -1 +0,0 @@ -!function(a){"use strict";redux.field_objects=redux.field_objects||{},redux.field_objects.button_set=redux.field_objects.button_set||{},a(document).ready(function(){if(void 0!==a.fn.button.noConflict){var b=a.fn.button.noConflict();a.fn.btn=b}}),redux.field_objects.button_set.init=function(b){b||(b=a(document).find(".redux-group-tab:visible").find(".redux-container-button_set:visible")),a(b).each(function(){var b=a(this),c=b;b.hasClass("redux-field-container")||(c=b.parents(".redux-field-container:first")),c.is(":hidden")||c.hasClass("redux-field-init")&&(c.removeClass("redux-field-init"),b.find(".buttonset").each(function(){a(this).is(":checkbox")&&a(this).find(".buttonset-item").button(),a(this).buttonset()}))})}}(jQuery); \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/button_set/field_button_set.php b/library/admin/ReduxCore/inc/fields/button_set/field_button_set.php deleted file mode 100644 index b46392d5..00000000 --- a/library/admin/ReduxCore/inc/fields/button_set/field_button_set.php +++ /dev/null @@ -1,151 +0,0 @@ -. - * - * @package Redux_Field - * @subpackage Button_Set - * @author Daniel J Griffiths (Ghost1227) - * @author Dovy Paukstys - * @version 3.0.0 - */ - -// Exit if accessed directly - if ( ! defined( 'ABSPATH' ) ) { - exit; - } - -// Don't duplicate me! - if ( ! class_exists( 'ReduxFramework_button_set' ) ) { - - /** - * Main ReduxFramework_button_set class - * - * @since 1.0.0 - */ - class ReduxFramework_button_set { - - /** - * Holds configuration settings for each field in a model. - * Defining the field options - * array['fields'] array Defines the fields to be shown by scaffolding. - * [fieldName] array Defines the options for a field, or just enables the field if array is not applied. - * ['name'] string Overrides the field name (default is the array key) - * ['model'] string (optional) Overrides the model if the field is a belongsTo associated value. - * ['width'] string Defines the width of the field for paginate views. Examples are "100px" or "auto" - * ['align'] string Alignment types for paginate views (left, right, center) - * ['format'] string Formatting options for paginate fields. Options include ('currency','nice','niceShort','timeAgoInWords' or a valid Date() format) - * ['title'] string Changes the field name shown in views. - * ['desc'] string The description shown in edit/create views. - * ['readonly'] boolean True prevents users from changing the value in edit/create forms. - * ['type'] string Defines the input type used by the Form helper (example 'password') - * ['options'] array Defines a list of string options for drop down lists. - * ['editor'] boolean If set to True will show a WYSIWYG editor for this field. - * ['default'] string The default value for create forms. - * - * @param array $arr (See above) - * - * @return Object A new editor object. - * */ - static $_properties = array( - 'id' => 'Identifier', - ); - - /** - * Field Constructor. - * Required - must call the parent constructor, then assign field and value to vars, and obviously call the render field function - * - * @since 1.0.0 - * @access public - * @return void - */ - function __construct( $field = array(), $value = '', $parent ) { - - $this->parent = $parent; - $this->field = $field; - $this->value = $value; - } - - /** - * Field Render Function. - * Takes the vars and outputs the HTML for the field in the settings - * - * @since 1.0.0 - * @access public - * @return void - */ - public function render() { - if ( !empty( $this->field['data'] ) && empty( $this->field['options'] ) ) { - if ( empty( $this->field['args'] ) ) { - $this->field['args'] = array(); - } - - $this->field['options'] = $this->parent->get_wordpress_data( $this->field['data'], $this->field['args'] ); - - if ( empty( $this->field['options'] ) ) { - return; - } - } - - // multi => true renders the field multi-selectable (checkbox vs radio) - echo '
    '; - $i = 0; - foreach ( $this->field['options'] as $k => $v ) { - - $selected = ''; - if ( isset( $this->field['multi'] ) && $this->field['multi'] == true ) { - $type = "checkbox"; - $multi_suffix = '[]'; - - if ( ! empty( $this->value ) && ! is_array( $this->value ) ) { - $this->value = array( $this->value ); - } - - if ( is_array( $this->value ) && in_array( $k, $this->value ) ) { - $selected = 'checked="checked"'; - } - - } else { - $multi_suffix = ""; - $type = "radio"; - $selected = checked( $this->value, $k, false ); - } - - echo ''; - echo ''; - } - - echo '
    '; - } - - /** - * Enqueue Function. - * If this field requires any scripts, or css define this function and register/enqueue the scripts/css - * - * @since 1.0.0 - * @access public - * @return void - */ - public function enqueue() { - - if (!wp_script_is ( 'redux-field-button-set-js' )) { - wp_enqueue_script( - 'redux-field-button-set-js', - ReduxFramework::$_url . 'inc/fields/button_set/field_button_set' . Redux_Functions::isMin() . '.js', - array( 'jquery', 'jquery-ui-core', 'redux-js' ), - time(), - true - ); - } - } - } - } \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/checkbox/field_checkbox.css b/library/admin/ReduxCore/inc/fields/checkbox/field_checkbox.css deleted file mode 100644 index f50c8561..00000000 --- a/library/admin/ReduxCore/inc/fields/checkbox/field_checkbox.css +++ /dev/null @@ -1 +0,0 @@ -.redux-container-checkbox label{vertical-align:top;width:100%}.redux-container-checkbox label .field-desc{margin-top:0;float:left;width:93%;clear:none} diff --git a/library/admin/ReduxCore/inc/fields/checkbox/field_checkbox.js b/library/admin/ReduxCore/inc/fields/checkbox/field_checkbox.js deleted file mode 100644 index ed72de33..00000000 --- a/library/admin/ReduxCore/inc/fields/checkbox/field_checkbox.js +++ /dev/null @@ -1,55 +0,0 @@ -/** - * Redux Checkbox - * Dependencies : jquery - * Feature added by : Dovy Paukstys - * Date : 17 June 2014 - */ - -/*global redux_change, wp, redux*/ - -(function( $ ) { - "use strict"; - - redux.field_objects = redux.field_objects || {}; - redux.field_objects.checkbox = redux.field_objects.checkbox || {}; - - $( document ).ready( - function() { - //redux.field_objects.checkbox.init(); - } - ); - - redux.field_objects.checkbox.init = function( selector ) { - if ( !selector ) { - selector = $( document ).find( ".redux-group-tab:visible" ).find( '.redux-container-checkbox:visible' ); - } - - $( selector ).each( - function() { - var el = $( this ); - var parent = el; - if ( !el.hasClass( 'redux-field-container' ) ) { - parent = el.parents( '.redux-field-container:first' ); - } - if ( parent.is( ":hidden" ) ) { // Skip hidden fields - return; - } - if ( parent.hasClass( 'redux-field-init' ) ) { - parent.removeClass( 'redux-field-init' ); - } else { - return; - } - el.find( '.checkbox' ).on( - 'click', function( e ) { - var val = 0; - if ( $( this ).is( ':checked' ) ) { - val = $( this ).parent().find( '.checkbox-check' ).attr( 'data-val' ); - } - $( this ).parent().find( '.checkbox-check' ).val( val ); - redux_change( $( this ) ); - } - ); - } - ); - }; -})( jQuery ); diff --git a/library/admin/ReduxCore/inc/fields/checkbox/field_checkbox.min.js b/library/admin/ReduxCore/inc/fields/checkbox/field_checkbox.min.js deleted file mode 100644 index 602a878e..00000000 --- a/library/admin/ReduxCore/inc/fields/checkbox/field_checkbox.min.js +++ /dev/null @@ -1 +0,0 @@ -!function(a){"use strict";redux.field_objects=redux.field_objects||{},redux.field_objects.checkbox=redux.field_objects.checkbox||{},a(document).ready(function(){}),redux.field_objects.checkbox.init=function(b){b||(b=a(document).find(".redux-group-tab:visible").find(".redux-container-checkbox:visible")),a(b).each(function(){var b=a(this),c=b;b.hasClass("redux-field-container")||(c=b.parents(".redux-field-container:first")),c.is(":hidden")||c.hasClass("redux-field-init")&&(c.removeClass("redux-field-init"),b.find(".checkbox").on("click",function(b){var c=0;a(this).is(":checked")&&(c=a(this).parent().find(".checkbox-check").attr("data-val")),a(this).parent().find(".checkbox-check").val(c),redux_change(a(this))}))})}}(jQuery); \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/checkbox/field_checkbox.php b/library/admin/ReduxCore/inc/fields/checkbox/field_checkbox.php deleted file mode 100644 index 6ccdcbe4..00000000 --- a/library/admin/ReduxCore/inc/fields/checkbox/field_checkbox.php +++ /dev/null @@ -1,159 +0,0 @@ -. - * - * @package ReduxFramework - * @subpackage Field_Checkbox - * @author Daniel J Griffiths (Ghost1227) - * @author Dovy Paukstys - * @version 3.0.0 - */ -// Exit if accessed directly -if ( !defined ( 'ABSPATH' ) ) { - exit; -} - -// Don't duplicate me! -if ( !class_exists ( 'ReduxFramework_checkbox' ) ) { - - /** - * Main ReduxFramework_checkbox class - * - * @since 1.0.0 - */ - class ReduxFramework_checkbox { - - /** - * Field Constructor. - * Required - must call the parent constructor, then assign field and value to vars, and obviously call the render field function - * - * @since 1.0.0 - * @access public - * @return void - */ - function __construct ( $field = array(), $value = '', $parent ) { - - $this->parent = $parent; - $this->field = $field; - $this->value = $value; - } - - /** - * Field Render Function. - * Takes the vars and outputs the HTML for the field in the settings - * - * @since 1.0.0 - * @access public - * @return void - */ - public function render () { - if( !empty( $this->field['data'] ) && empty( $this->field['options'] ) ) { - if (empty($this->field['args'])) { - $this->field['args'] = array(); - } - - $this->field['options'] = $this->parent->get_wordpress_data($this->field['data'], $this->field['args']); - if (empty($this->field['options'])) { - return; - } - } - - $this->field[ 'data_class' ] = ( isset ( $this->field[ 'multi_layout' ] ) ) ? 'data-' . $this->field[ 'multi_layout' ] : 'data-full'; - - if ( !empty ( $this->field[ 'options' ] ) && ( is_array ( $this->field[ 'options' ] ) || is_array ( $this->field[ 'default' ] ) ) ) { - - echo '
      '; - - if ( !isset ( $this->value ) ) { - $this->value = array(); - } - - if ( !is_array ( $this->value ) ) { - $this->value = array(); - } - - if ( empty ( $this->field[ 'options' ] ) && isset ( $this->field[ 'default' ] ) && is_array ( $this->field[ 'default' ] ) ) { - $this->field[ 'options' ] = $this->field[ 'default' ]; - } - - foreach ( $this->field[ 'options' ] as $k => $v ) { - - if ( empty ( $this->value[ $k ] ) ) { - $this->value[ $k ] = ""; - } - - echo '
    • '; - echo ''; - echo '
    • '; - } - - echo '
    '; - } else if ( empty ( $this->field[ 'data' ] ) ) { - - echo (!empty ( $this->field[ 'desc' ] ) ) ? '
    '; - } - } - - /** - * Enqueue Function. - * If this field requires any scripts, or css define this function and register/enqueue the scripts/css - * - * @since 1.0.0 - * @access public - * @return void - */ - public function enqueue () { - - if ($this->parent->args['dev_mode']) { - wp_enqueue_style ( - 'redux-field-checkbox-css', - ReduxFramework::$_url . 'inc/fields/checkbox/field_checkbox.css', - array(), - time (), - 'all' - ); - } - - wp_enqueue_script ( - 'redux-field-checkbox-js', - ReduxFramework::$_url . 'inc/fields/checkbox/field_checkbox' . Redux_Functions::isMin () . '.js', - array( 'jquery', 'redux-js' ), - time (), - true - ); - } - } - -} diff --git a/library/admin/ReduxCore/inc/fields/checkbox/field_checkbox.scss b/library/admin/ReduxCore/inc/fields/checkbox/field_checkbox.scss deleted file mode 100644 index 7dca5ebe..00000000 --- a/library/admin/ReduxCore/inc/fields/checkbox/field_checkbox.scss +++ /dev/null @@ -1,13 +0,0 @@ -.redux-container-checkbox { - label { - vertical-align: top; - width: 100%; - - .field-desc { - margin-top: 0; - float: left; - width: 93%; - clear: none; - } - } -} \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/color/field_color.js b/library/admin/ReduxCore/inc/fields/color/field_color.js deleted file mode 100644 index de71c220..00000000 --- a/library/admin/ReduxCore/inc/fields/color/field_color.js +++ /dev/null @@ -1,176 +0,0 @@ -/* - Field Color (color) - */ - -/*global jQuery, document, redux_change, redux*/ - -(function( $ ) { - 'use strict'; - - redux.field_objects = redux.field_objects || {}; - redux.field_objects.color = redux.field_objects.color || {}; - - $( document ).ready( - function() { - - } - ); - - redux.field_objects.color.init = function( selector ) { - - if ( !selector ) { - selector = $( document ).find( ".redux-group-tab:visible" ).find( '.redux-container-color:visible' ); - } - - $( selector ).each( - function() { - - var el = $( this ); - var parent = el; - - if ( !el.hasClass( 'redux-field-container' ) ) { - parent = el.parents( '.redux-field-container:first' ); - } - if ( parent.is( ":hidden" ) ) { // Skip hidden fields - return; - } - if ( parent.hasClass( 'redux-field-init' ) ) { - parent.removeClass( 'redux-field-init' ); - } else { - return; - } -// var $control = el.find( '.redux-color-init' ), -// -// value = $control.val().replace( /\s+/g, '' ), -// alpha_val = 100, -// $alpha, $alpha_output; -// //console.log($control); -// if ( value.match( /rgba\(\d+\,\d+\,\d+\,([^\)]+)\)/ ) ) { -// alpha_val = parseFloat( value.match( /rgba\(\d+\,\d+\,\d+\,([^\)]+)\)/ )[ 1 ] ) * 100; -// } - el.find( '.redux-color-init' ).wpColorPicker( - { - change: function( e, ui ) { - $( this ).val( ui.color.toString() ); - redux_change( $( this ) ); - el.find( '#' + e.target.getAttribute( 'data-id' ) + '-transparency' ).removeAttr( 'checked' ); - }, - clear: function( e, ui ) { - $( this ).val( ui.color.toString() ); - redux_change( $( this ).parent().find( '.redux-color-init' ) ); - } - } - ); -// $( '
    ' -// + '' -// + '' -// + '
    ' ).appendTo( $control.parents( '.wp-picker-container:first' ).addClass( 'vc_color-picker' ).find( '.iris-picker' ) ); -// $alpha = $control.parents( '.wp-picker-container:first' ).find( '.vc_alpha-field' ); -// //console.log($alpha); -// $alpha_output = $control.parents( '.wp-picker-container:first' ).find( '.redux-alpha-container output' ); -// $alpha.bind( 'change keyup', function () { -// var alpha_val = parseFloat( $alpha.val() ), -// iris = $control.data( 'a8cIris' ), -// color_picker = $control.data( 'wp-wpColorPicker' ); -// //console.log(alpha_val); -// $alpha_output.val( $alpha.val() + '%' ); -// console.log(alpha_val / 100.0); -// iris._color._alpha = parseFloat(alpha_val / 100.0); -// console.log(iris._color); -// //$control.val( iris._color.toString() ); -// el.find( '.redux-color-init' ).wpColorPicker( 'color', iris._color.toString() ); -// //console.log($control.val()); -// //color_picker.toggler.css( { backgroundColor: $control.val() } ); -// } ).val( alpha_val ).trigger( 'change' ); - - el.find( '.redux-color' ).on( - 'focus', function() { - $( this ).data( 'oldcolor', $( this ).val() ); - } - ); - - el.find( '.redux-color' ).on( - 'keyup', function() { - var value = $( this ).val(); - var color = colorValidate( this ); - var id = '#' + $( this ).attr( 'id' ); - - if ( value === "transparent" ) { - $( this ).parent().parent().find( '.wp-color-result' ).css( - 'background-color', 'transparent' - ); - - el.find( id + '-transparency' ).attr( 'checked', 'checked' ); - } else { - el.find( id + '-transparency' ).removeAttr( 'checked' ); - - if ( color && color !== $( this ).val() ) { - $( this ).val( color ); - } - } - } - ); - - // Replace and validate field on blur - el.find( '.redux-color' ).on( - 'blur', function() { - var value = $( this ).val(); - var id = '#' + $( this ).attr( 'id' ); - - if ( value === "transparent" ) { - $( this ).parent().parent().find( '.wp-color-result' ).css( - 'background-color', 'transparent' - ); - - el.find( id + '-transparency' ).attr( 'checked', 'checked' ); - } else { - if ( colorValidate( this ) === value ) { - if ( value.indexOf( "#" ) !== 0 ) { - $( this ).val( $( this ).data( 'oldcolor' ) ); - } - } - - el.find( id + '-transparency' ).removeAttr( 'checked' ); - } - } - ); - - // Store the old valid color on keydown - el.find( '.redux-color' ).on( - 'keydown', function() { - $( this ).data( 'oldkeypress', $( this ).val() ); - } - ); - - // When transparency checkbox is clicked - el.find( '.color-transparency' ).on( - 'click', function() { - if ( $( this ).is( ":checked" ) ) { - - el.find( '.redux-saved-color' ).val( $( '#' + $( this ).data( 'id' ) ).val() ); - el.find( '#' + $( this ).data( 'id' ) ).val( 'transparent' ); - el.find( '#' + $( this ).data( 'id' ) ).parent().parent().find( '.wp-color-result' ).css( - 'background-color', 'transparent' - ); - } else { - if ( el.find( '#' + $( this ).data( 'id' ) ).val() === 'transparent' ) { - var prevColor = $( '.redux-saved-color' ).val(); - - if ( prevColor === '' ) { - prevColor = $( '#' + $( this ).data( 'id' ) ).data( 'default-color' ); - } - - el.find( '#' + $( this ).data( 'id' ) ).parent().parent().find( '.wp-color-result' ).css( - 'background-color', prevColor - ); - - el.find( '#' + $( this ).data( 'id' ) ).val( prevColor ); - } - } - redux_change( $( this ) ); - } - ); - } - ); - }; -})( jQuery ); \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/color/field_color.min.js b/library/admin/ReduxCore/inc/fields/color/field_color.min.js deleted file mode 100644 index b3c810a3..00000000 --- a/library/admin/ReduxCore/inc/fields/color/field_color.min.js +++ /dev/null @@ -1 +0,0 @@ -!function(a){"use strict";redux.field_objects=redux.field_objects||{},redux.field_objects.color=redux.field_objects.color||{},a(document).ready(function(){}),redux.field_objects.color.init=function(b){b||(b=a(document).find(".redux-group-tab:visible").find(".redux-container-color:visible")),a(b).each(function(){var b=a(this),c=b;b.hasClass("redux-field-container")||(c=b.parents(".redux-field-container:first")),c.is(":hidden")||c.hasClass("redux-field-init")&&(c.removeClass("redux-field-init"),b.find(".redux-color-init").wpColorPicker({change:function(c,d){a(this).val(d.color.toString()),redux_change(a(this)),b.find("#"+c.target.getAttribute("data-id")+"-transparency").removeAttr("checked")},clear:function(b,c){a(this).val(c.color.toString()),redux_change(a(this).parent().find(".redux-color-init"))}}),b.find(".redux-color").on("focus",function(){a(this).data("oldcolor",a(this).val())}),b.find(".redux-color").on("keyup",function(){var c=a(this).val(),d=colorValidate(this),e="#"+a(this).attr("id");"transparent"===c?(a(this).parent().parent().find(".wp-color-result").css("background-color","transparent"),b.find(e+"-transparency").attr("checked","checked")):(b.find(e+"-transparency").removeAttr("checked"),d&&d!==a(this).val()&&a(this).val(d))}),b.find(".redux-color").on("blur",function(){var c=a(this).val(),d="#"+a(this).attr("id");"transparent"===c?(a(this).parent().parent().find(".wp-color-result").css("background-color","transparent"),b.find(d+"-transparency").attr("checked","checked")):(colorValidate(this)===c&&0!==c.indexOf("#")&&a(this).val(a(this).data("oldcolor")),b.find(d+"-transparency").removeAttr("checked"))}),b.find(".redux-color").on("keydown",function(){a(this).data("oldkeypress",a(this).val())}),b.find(".color-transparency").on("click",function(){if(a(this).is(":checked"))b.find(".redux-saved-color").val(a("#"+a(this).data("id")).val()),b.find("#"+a(this).data("id")).val("transparent"),b.find("#"+a(this).data("id")).parent().parent().find(".wp-color-result").css("background-color","transparent");else if("transparent"===b.find("#"+a(this).data("id")).val()){var c=a(".redux-saved-color").val();""===c&&(c=a("#"+a(this).data("id")).data("default-color")),b.find("#"+a(this).data("id")).parent().parent().find(".wp-color-result").css("background-color",c),b.find("#"+a(this).data("id")).val(c)}redux_change(a(this))}))})}}(jQuery); \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/color/field_color.php b/library/admin/ReduxCore/inc/fields/color/field_color.php deleted file mode 100644 index d353453f..00000000 --- a/library/admin/ReduxCore/inc/fields/color/field_color.php +++ /dev/null @@ -1,122 +0,0 @@ -. - * - * @package ReduxFramework - * @subpackage Field_Color - * @author Daniel J Griffiths (Ghost1227) - * @author Dovy Paukstys - * @version 3.0.0 - */ - -// Exit if accessed directly -if ( ! defined( 'ABSPATH' ) ) { - exit; -} - -// Don't duplicate me! -if ( ! class_exists( 'ReduxFramework_color' ) ) { - - /** - * Main ReduxFramework_color class - * - * @since 1.0.0 - */ - class ReduxFramework_color { - - /** - * Field Constructor. - * Required - must call the parent constructor, then assign field and value to vars, and obviously call the render field function - * - * @since 1.0.0 - * @access public - * @return void - */ - function __construct( $field = array(), $value = '', $parent ) { - - $this->parent = $parent; - $this->field = $field; - $this->value = $value; - } - - /** - * Field Render Function. - * Takes the vars and outputs the HTML for the field in the settings - * - * @since 1.0.0 - * @access public - * @return void - */ - public function render() { - - echo ''; - echo ''; - - if ( ! isset( $this->field['transparent'] ) || $this->field['transparent'] !== false ) { - - $tChecked = ""; - - if ( $this->value == "transparent" ) { - $tChecked = ' checked="checked"'; - } - - echo ''; - } - } - - /** - * Enqueue Function. - * If this field requires any scripts, or css define this function and register/enqueue the scripts/css - * - * @since 1.0.0 - * @access public - * @return void - */ - public function enqueue() { - if ($this->parent->args['dev_mode']) { - wp_enqueue_style( 'redux-color-picker-css' ); - } - - wp_enqueue_style( 'wp-color-picker' ); - - wp_enqueue_script( - 'redux-field-color-js', - ReduxFramework::$_url . 'inc/fields/color/field_color' . Redux_Functions::isMin() . '.js', - array( 'jquery', 'wp-color-picker', 'redux-js' ), - time(), - true - ); - } - - public function output() { - $style = ''; - - if ( ! empty( $this->value ) ) { - $mode = ( isset( $this->field['mode'] ) && ! empty( $this->field['mode'] ) ? $this->field['mode'] : 'color' ); - - $style .= $mode . ':' . $this->value . ';'; - - if ( ! empty( $this->field['output'] ) && is_array( $this->field['output'] ) ) { - $css = Redux_Functions::parseCSS( $this->field['output'], $style, $this->value ); - $this->parent->outputCSS .= $css; - } - - if ( ! empty( $this->field['compiler'] ) && is_array( $this->field['compiler'] ) ) { - $css = Redux_Functions::parseCSS( $this->field['compiler'], $style, $this->value ); - $this->parent->compilerCSS .= $css; - - } - } - } - } -} diff --git a/library/admin/ReduxCore/inc/fields/color_gradient/field_color_gradient.css b/library/admin/ReduxCore/inc/fields/color_gradient/field_color_gradient.css deleted file mode 100644 index 58dc4552..00000000 --- a/library/admin/ReduxCore/inc/fields/color_gradient/field_color_gradient.css +++ /dev/null @@ -1 +0,0 @@ -.redux-container-color_gradient .colorGradient{display:inline-block}.redux-container-color_gradient .toLabel{padding-left:18px}@media screen and (max-width: 660px){.redux-container-color_gradient .colorGradient{display:block;text-align:center !important}} diff --git a/library/admin/ReduxCore/inc/fields/color_gradient/field_color_gradient.js b/library/admin/ReduxCore/inc/fields/color_gradient/field_color_gradient.js deleted file mode 100644 index 55e61295..00000000 --- a/library/admin/ReduxCore/inc/fields/color_gradient/field_color_gradient.js +++ /dev/null @@ -1,142 +0,0 @@ -/* - Field Color Gradient - */ - -/*global jQuery, document, redux_change, redux*/ - -(function( $ ) { - 'use strict'; - - redux.field_objects = redux.field_objects || {}; - redux.field_objects.color_gradient = redux.field_objects.color_gradient || {}; - - $( document ).ready( - function() { - // setTimeout(function () { - // redux.field_objects.color.init(); - // }, 1000); - } - ); - - redux.field_objects.color_gradient.init = function( selector ) { - - if ( !selector ) { - selector = $( document ).find( ".redux-group-tab:visible" ).find( '.redux-container-color_gradient:visible' ); - } - - $( selector ).each( - function() { - var el = $( this ); - var parent = el; - - if ( !el.hasClass( 'redux-field-container' ) ) { - parent = el.parents( '.redux-field-container:first' ); - } - if ( parent.is( ":hidden" ) ) { // Skip hidden fields - return; - } - if ( parent.hasClass( 'redux-field-init' ) ) { - parent.removeClass( 'redux-field-init' ); - } else { - return; - } - - el.find( '.redux-color-init' ).wpColorPicker( - { - change: function( e, ui ) { - $( this ).val( ui.color.toString() ); - redux_change( $( this ) ); - el.find( '#' + e.target.getAttribute( 'data-id' ) + '-transparency' ).removeAttr( 'checked' ); - }, - clear: function( e, ui ) { - $( this ).val( ui.color.toString() ); - redux_change( $( this ).parent().find( '.redux-color-init' ) ); - } - } - ); - - el.find( '.redux-color' ).on( - 'keyup', function() { - var value = $( this ).val(); - var color = colorValidate( this ); - var id = '#' + $( this ).attr( 'id' ); - - if ( value === "transparent" ) { - $( this ).parent().parent().find( '.wp-color-result' ).css( - 'background-color', 'transparent' - ); - - el.find( id + '-transparency' ).attr( 'checked', 'checked' ); - } else { - el.find( id + '-transparency' ).removeAttr( 'checked' ); - - if ( color && color !== $( this ).val() ) { - $( this ).val( color ); - } - } - } - ); - - // Replace and validate field on blur - el.find( '.redux-color' ).on( - 'blur', function() { - var value = $( this ).val(); - var id = '#' + $( this ).attr( 'id' ); - - if ( value === "transparent" ) { - $( this ).parent().parent().find( '.wp-color-result' ).css( - 'background-color', 'transparent' - ); - - el.find( id + '-transparency' ).attr( 'checked', 'checked' ); - } else { - if ( colorValidate( this ) === value ) { - if ( value.indexOf( "#" ) !== 0 ) { - $( this ).val( $( this ).data( 'oldcolor' ) ); - } - } - - el.find( id + '-transparency' ).removeAttr( 'checked' ); - } - } - ); - - // Store the old valid color on keydown - el.find( '.redux-color' ).on( - 'keydown', function() { - $( this ).data( 'oldkeypress', $( this ).val() ); - } - ); - - // When transparency checkbox is clicked - el.find( '.color-transparency' ).on( - 'click', function() { - if ( $( this ).is( ":checked" ) ) { - - el.find( '.redux-saved-color' ).val( $( '#' + $( this ).data( 'id' ) ).val() ); - el.find( '#' + $( this ).data( 'id' ) ).val( 'transparent' ); - el.find( '#' + $( this ).data( 'id' ) ).parent().parent().find( '.wp-color-result' ).css( - 'background-color', 'transparent' - ); - } else { - if ( el.find( '#' + $( this ).data( 'id' ) ).val() === 'transparent' ) { - var prevColor = $( '.redux-saved-color' ).val(); - - if ( prevColor === '' ) { - prevColor = $( '#' + $( this ).data( 'id' ) ).data( 'default-color' ); - } - - el.find( '#' + $( this ).data( 'id' ) ).parent().parent().find( '.wp-color-result' ).css( - 'background-color', prevColor - ); - - el.find( '#' + $( this ).data( 'id' ) ).val( prevColor ); - } - } - redux_change( $( this ) ); - } - ); - } - ); - }; -})( jQuery ); \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/color_gradient/field_color_gradient.min.js b/library/admin/ReduxCore/inc/fields/color_gradient/field_color_gradient.min.js deleted file mode 100644 index 86a8490f..00000000 --- a/library/admin/ReduxCore/inc/fields/color_gradient/field_color_gradient.min.js +++ /dev/null @@ -1 +0,0 @@ -!function(a){"use strict";redux.field_objects=redux.field_objects||{},redux.field_objects.color_gradient=redux.field_objects.color_gradient||{},a(document).ready(function(){}),redux.field_objects.color_gradient.init=function(b){b||(b=a(document).find(".redux-group-tab:visible").find(".redux-container-color_gradient:visible")),a(b).each(function(){var b=a(this),c=b;b.hasClass("redux-field-container")||(c=b.parents(".redux-field-container:first")),c.is(":hidden")||c.hasClass("redux-field-init")&&(c.removeClass("redux-field-init"),b.find(".redux-color-init").wpColorPicker({change:function(c,d){a(this).val(d.color.toString()),redux_change(a(this)),b.find("#"+c.target.getAttribute("data-id")+"-transparency").removeAttr("checked")},clear:function(b,c){a(this).val(c.color.toString()),redux_change(a(this).parent().find(".redux-color-init"))}}),b.find(".redux-color").on("keyup",function(){var c=a(this).val(),d=colorValidate(this),e="#"+a(this).attr("id");"transparent"===c?(a(this).parent().parent().find(".wp-color-result").css("background-color","transparent"),b.find(e+"-transparency").attr("checked","checked")):(b.find(e+"-transparency").removeAttr("checked"),d&&d!==a(this).val()&&a(this).val(d))}),b.find(".redux-color").on("blur",function(){var c=a(this).val(),d="#"+a(this).attr("id");"transparent"===c?(a(this).parent().parent().find(".wp-color-result").css("background-color","transparent"),b.find(d+"-transparency").attr("checked","checked")):(colorValidate(this)===c&&0!==c.indexOf("#")&&a(this).val(a(this).data("oldcolor")),b.find(d+"-transparency").removeAttr("checked"))}),b.find(".redux-color").on("keydown",function(){a(this).data("oldkeypress",a(this).val())}),b.find(".color-transparency").on("click",function(){if(a(this).is(":checked"))b.find(".redux-saved-color").val(a("#"+a(this).data("id")).val()),b.find("#"+a(this).data("id")).val("transparent"),b.find("#"+a(this).data("id")).parent().parent().find(".wp-color-result").css("background-color","transparent");else if("transparent"===b.find("#"+a(this).data("id")).val()){var c=a(".redux-saved-color").val();""===c&&(c=a("#"+a(this).data("id")).data("default-color")),b.find("#"+a(this).data("id")).parent().parent().find(".wp-color-result").css("background-color",c),b.find("#"+a(this).data("id")).val(c)}redux_change(a(this))}))})}}(jQuery); \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/color_gradient/field_color_gradient.php b/library/admin/ReduxCore/inc/fields/color_gradient/field_color_gradient.php deleted file mode 100644 index 41dfeeb4..00000000 --- a/library/admin/ReduxCore/inc/fields/color_gradient/field_color_gradient.php +++ /dev/null @@ -1,128 +0,0 @@ -. - * - * @package ReduxFramework - * @subpackage Field_Color_Gradient - * @author Daniel J Griffiths (Ghost1227) - * @author Dovy Paukstys - * @version 3.0.0 - */ -// Exit if accessed directly -if ( ! defined( 'ABSPATH' ) ) { - exit; -} - -// Don't duplicate me! -if ( ! class_exists( 'ReduxFramework_color_gradient' ) ) { - - /** - * Main ReduxFramework_color_gradient class - * - * @since 1.0.0 - */ - class ReduxFramework_color_gradient { - - /** - * Field Constructor. - * Required - must call the parent constructor, then assign field and value to vars, and obviously call the render field function - * - * @since 1.0.0 - * @access public - * @return void - */ - function __construct( $field = array(), $value = '', $parent ) { - $this->parent = $parent; - $this->field = $field; - $this->value = $value; - } - - /** - * Field Render Function. - * Takes the vars and outputs the HTML for the field in the settings - * - * @since 1.0.0 - * @access public - * @return void - */ - public function render() { - - // No errors please - $defaults = array( - 'from' => '', - 'to' => '' - ); - - $this->value = wp_parse_args( $this->value, $defaults ); - - echo '
    ' . __( 'From ', 'redux-framework' ) . ' '; - echo ''; - echo ''; - - if ( ! isset( $this->field['transparent'] ) || $this->field['transparent'] !== false ) { - $tChecked = ""; - - if ( $this->value['from'] == "transparent" ) { - $tChecked = ' checked="checked"'; - } - - echo ''; - } - echo "
    "; - echo '
    ' . __( 'To ', 'redux-framework' ) . ' '; - - if ( ! isset( $this->field['transparent'] ) || $this->field['transparent'] !== false ) { - $tChecked = ""; - - if ( $this->value['to'] == "transparent" ) { - $tChecked = ' checked="checked"'; - } - - echo ''; - } - echo "
    "; - } - - /** - * Enqueue Function. - * If this field requires any scripts, or css define this function and register/enqueue the scripts/css - * - * @since 1.0.0 - * @access public - * @return void - */ - public function enqueue() { - wp_enqueue_style( 'wp-color-picker' ); - - wp_enqueue_script( - 'redux-field-color-gradient-js', - ReduxFramework::$_url . 'inc/fields/color_gradient/field_color_gradient' . Redux_Functions::isMin() . '.js', - array( 'jquery', 'wp-color-picker', 'redux-js' ), - time(), - 'all' - ); - - if ($this->parent->args['dev_mode']) { - wp_enqueue_style( 'redux-color-picker-css' ); - - wp_enqueue_style( - 'redux-field-color_gradient-css', - ReduxFramework::$_url . 'inc/fields/color_gradient/field_color_gradient.css', - array(), - time(), - 'all' - ); - } - } - } -} \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/color_gradient/field_color_gradient.scss b/library/admin/ReduxCore/inc/fields/color_gradient/field_color_gradient.scss deleted file mode 100644 index 00508fcb..00000000 --- a/library/admin/ReduxCore/inc/fields/color_gradient/field_color_gradient.scss +++ /dev/null @@ -1,17 +0,0 @@ -.redux-container-color_gradient { - .colorGradient { - display: inline-block; - } - .toLabel { - padding-left: 18px; - } -} - -@media screen and (max-width: 660px) { - .redux-container-color_gradient { - .colorGradient { - display: block; - text-align: center !important; - } - } -} \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/color_rgba/field_color_rgba.css b/library/admin/ReduxCore/inc/fields/color_rgba/field_color_rgba.css deleted file mode 100644 index b52a1cc2..00000000 --- a/library/admin/ReduxCore/inc/fields/color_rgba/field_color_rgba.css +++ /dev/null @@ -1 +0,0 @@ -.sp-container{color:#555;border-color:#cccccc;background:#f7f7f7;-webkit-box-shadow:inset 0 1px 0 #fff,0 1px 0 rgba(0,0,0,0.08);box-shadow:inset 0 1px 0 #fff,0 1px 0 rgba(0,0,0,0.08);vertical-align:top}.sp-replacer{color:#555;border-color:#cccccc;background:#f7f7f7;-webkit-box-shadow:inset 0 1px 0 #fff,0 1px 0 rgba(0,0,0,0.08);box-shadow:inset 0 1px 0 #fff,0 1px 0 rgba(0,0,0,0.08);vertical-align:top}.sp-replacer:focus,.sp-replacer:hover,.sp-replacer.focus,.sp-replacer.hover{background:#fafafa;border-color:#999;color:#222}.sp-replacer:focus,.sp-replacer.focus{-webkit-box-shadow:0 0 0 1px #5b9dd9,0 0 2px 1px rgba(30,140,190,0.8);box-shadow:0 0 0 1px #5b9dd9,0 0 2px 1px rgba(30,140,190,0.8)}.sp-replacer.active:focus{-webkit-box-shadow:inset 0 2px 5px -3px rgba(0,0,0,0.5),0 0 0 1px #5b9dd9,0 0 2px 1px rgba(30,140,190,0.8);box-shadow:inset 0 2px 5px -3px rgba(0,0,0,0.5),0 0 0 1px #5b9dd9,0 0 2px 1px rgba(30,140,190,0.8)}.sp-replacer.active,.sp-replacer.active:hover,.sp-replacer:active{background:#eee;border-color:#999;color:#333;-webkit-box-shadow:inset 0 2px 5px -3px rgba(0,0,0,0.5);box-shadow:inset 0 2px 5px -3px rgba(0,0,0,0.5)} diff --git a/library/admin/ReduxCore/inc/fields/color_rgba/field_color_rgba.js b/library/admin/ReduxCore/inc/fields/color_rgba/field_color_rgba.js deleted file mode 100644 index 4a38f26c..00000000 --- a/library/admin/ReduxCore/inc/fields/color_rgba/field_color_rgba.js +++ /dev/null @@ -1,217 +0,0 @@ -(function($){ - 'use strict'; - - redux.field_objects = redux.field_objects || {}; - redux.field_objects.color_rgba = redux.field_objects.color_rgba || {}; - redux.field_objects.color_rgba.fieldID = ''; - - redux.field_objects.color_rgba.hexToRGBA = function( hex, alpha ) { - var result; - - if (hex === null) { - result = ''; - } else { - hex = hex.replace('#', ''); - var r = parseInt(hex.substring(0, 2), 16); - var g = parseInt(hex.substring(2, 4), 16); - var b = parseInt(hex.substring(4, 6), 16); - - result = 'rgba(' + r + ',' + g + ',' + b + ',' + alpha + ')'; - } - - return result; - }; - - redux.field_objects.color_rgba.init = function( selector ) { - if ( !selector ) { - selector = $( document ).find( ".redux-group-tab:visible" ).find( '.redux-container-color_rgba:visible' ); - } - - $( selector ).each( - function() { - var el = $( this ); - var parent = el; - - if ( !el.hasClass( 'redux-field-container' ) ) { - parent = el.parents( '.redux-field-container:first' ); - } - - if ( parent.is( ":hidden" ) ) { // Skip hidden fields - return; - } - - if ( parent.hasClass( 'redux-field-init' ) ) { - parent.removeClass( 'redux-field-init' ); - } else { - return; - } - - redux.field_objects.color_rgba.modInit(el); - redux.field_objects.color_rgba.initColorPicker(el); - }); - }; - - redux.field_objects.color_rgba.modInit = function(el) { - - redux.field_objects.color_rgba.fieldID = el.find('.redux-color_rgba-container').data('id'); - - }; - - // Initialize colour picker - redux.field_objects.color_rgba.initColorPicker = function(el){ - - // Get field ID - var field_id = redux.field_objects.color_rgba.fieldID; - - // Get the color scheme container - var colorpickerInput = el.find('.redux-color-rgba'); - - // Get alpha value and sanitize it - var currentAlpha = colorpickerInput.data('current-alpha'); - currentAlpha = Number((currentAlpha === null || currentAlpha === undefined) ? 1 : currentAlpha); - - // Get colour value and sanitize it - var currentColor = colorpickerInput.data('current-color'); - currentColor = (currentColor === '' || currentColor === 'transparent') ? '' : currentColor; - - var outputTransparent = colorpickerInput.data('output-transparent'); - outputTransparent = Boolean((outputTransparent === '') ? false : outputTransparent); - - // Color picker arguments - var container = el.find('.redux-color-rgba-container'); - - // Get, decode and parse palette. - var palette = container.data('palette'); - palette = decodeURIComponent(palette); - palette = JSON.parse(palette); - - // Default palette - if (palette === null) { - palette = [ - ["#000000", "#434343", "#666666", "#999999", "#b7b7b7", "#cccccc", "#d9d9d9", "#efefef", "#f3f3f3", "#ffffff"], - ["#980000", "#ff0000", "#ff9900", "#ffff00", "#00ff00", "#00ffff", "#4a86e8", "#0000ff", "#9900ff", "#ff00ff"], - ["#e6b8af", "#f4cccc", "#fce5cd", "#fff2cc", "#d9ead3", "#d9ead3", "#c9daf8", "#cfe2f3", "#d9d2e9", "#ead1dc"], - ["#dd7e6b", "#ea9999", "#f9cb9c", "#ffe599", "#b6d7a8", "#a2c4c9", "#a4c2f4", "#9fc5e8", "#b4a7d6", "#d5a6bd"], - ["#cc4125", "#e06666", "#f6b26b", "#ffd966", "#93c47d", "#76a5af", "#6d9eeb", "#6fa8dc", "#8e7cc3", "#c27ba0"], - ["#a61c00", "#cc0000", "#e69138", "#f1c232", "#6aa84f", "#45818e", "#3c78d8", "#3d85c6", "#674ea7", "#a64d79"], - ["#85200c", "#990000", "#b45f06", "#bf9000", "#38761d", "#134f5c", "#1155cc", "#0b5394", "#351c75", "#741b47"], - ["#5b0f00", "#660000", "#783f04", "#7f6000", "#274e13", "#0c343d", "#1c4587", "#073763", "#20124d", "#4c1130"] - ]; - } - - // Get and sanitize show input argument - var showInput = container.data('show-input'); - showInput = Boolean((showInput === '') ? false : showInput); - - // Get and sanitize show initial argument - var showInitial = container.data('show-initial'); - showInitial = Boolean((showInitial === '') ? false : showInitial); - - // Get and sanitize show alpha argument - var showAlpha = container.data('show-alpha'); - showAlpha = Boolean((showAlpha === '') ? false : showAlpha); - - // Get and sanitize allow empty argument - var allowEmpty = container.data('allow-empty'); - allowEmpty = Boolean((allowEmpty === '') ? false : allowEmpty); - - // Get and sanitize show palette argument - var showPalette = container.data('show-palette'); - showPalette = Boolean((showPalette === '') ? false : showPalette); - - // Get and sanitize show palette only argument - var showPaletteOnly = container.data('show-palette-only'); - showPaletteOnly = Boolean((showPaletteOnly === '') ? false : showPaletteOnly); - - // Get and sanitize show selection palette argument - var showSelectionPalette = container.data('show-selection-palette'); - showSelectionPalette = Boolean((showSelectionPalette === '') ? false : showSelectionPalette); - - // Get max palette size - var maxPaletteSize = Number(container.data('max-palette-size')); - - // Get and sanitize clickout fires change argument - var clickoutFiresChange = container.data('clickout-fires-change'); - clickoutFiresChange = Boolean((clickoutFiresChange === '') ? false : clickoutFiresChange); - - // Get choose button text - var chooseText = String(container.data('choose-text')); - - // Get cancel button text - var cancelText = String(container.data('cancel-text')); - - // Get cancel button text - var inputText = String(container.data('input-text')); - - - // Get and sanitize show buttons argument - var showButtons = container.data('show-buttons'); - showButtons = Boolean((showButtons === '') ? false : showButtons); - - // Get container class - var containerClass = String(container.data('container-class')); - - // Get replacer class - var replacerClass = String(container.data('replacer-class')); - - // Color picker options - colorpickerInput.spectrum({ - color: currentColor, //'#ffffff', - showAlpha: showAlpha, - showInput: showInput, - allowEmpty: allowEmpty, - className: 'redux-color-rgba', - showInitial: showInitial, - showPalette: showPalette, - showSelectionPalette: showSelectionPalette, - maxPaletteSize: maxPaletteSize, - showPaletteOnly: showPaletteOnly, - clickoutFiresChange: clickoutFiresChange, - chooseText: chooseText, - cancelText: cancelText, - showButtons: showButtons, - containerClassName: containerClass, - replacerClassName: replacerClass, - preferredFormat: 'hex6', - localStorageKey: 'redux.color-rgba.' + field_id, - palette: palette, - inputText: inputText, - - // on change - change: function(color) { - var colorVal, alphaVal, rgbaVal; - - if (color === null) { - if (outputTransparent === true) { - colorVal = 'transparent'; - } else { - colorVal = null; - } - alphaVal = null; - } else { - colorVal = color.toHexString(); - alphaVal = color.alpha; - } - - if (colorVal != 'transparent') { - rgbaVal = redux.field_objects.color_rgba.hexToRGBA(colorVal, alphaVal); - } else { - rgbaVal = 'transparent'; - } - - var blockID = $(this).data('block-id'); - - // Update HTML color value - el.find('input#' + blockID + '-color').val(colorVal); - - // Update HTML alpha value - el.find('input#' + blockID + '-alpha').val(alphaVal); - - // Update RGBA alpha value - el.find('input#' + blockID + '-rgba').val(rgbaVal); - - redux_change(el.find('.redux-color-rgba-container')); - } - }); - }; -})(jQuery); \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/color_rgba/field_color_rgba.min.js b/library/admin/ReduxCore/inc/fields/color_rgba/field_color_rgba.min.js deleted file mode 100644 index 958ecdca..00000000 --- a/library/admin/ReduxCore/inc/fields/color_rgba/field_color_rgba.min.js +++ /dev/null @@ -1 +0,0 @@ -!function(a){"use strict";redux.field_objects=redux.field_objects||{},redux.field_objects.color_rgba=redux.field_objects.color_rgba||{},redux.field_objects.color_rgba.fieldID="",redux.field_objects.color_rgba.hexToRGBA=function(a,b){var c;if(null===a)c="";else{a=a.replace("#","");var d=parseInt(a.substring(0,2),16),e=parseInt(a.substring(2,4),16),f=parseInt(a.substring(4,6),16);c="rgba("+d+","+e+","+f+","+b+")"}return c},redux.field_objects.color_rgba.init=function(b){b||(b=a(document).find(".redux-group-tab:visible").find(".redux-container-color_rgba:visible")),a(b).each(function(){var b=a(this),c=b;b.hasClass("redux-field-container")||(c=b.parents(".redux-field-container:first")),c.is(":hidden")||c.hasClass("redux-field-init")&&(c.removeClass("redux-field-init"),redux.field_objects.color_rgba.modInit(b),redux.field_objects.color_rgba.initColorPicker(b))})},redux.field_objects.color_rgba.modInit=function(a){redux.field_objects.color_rgba.fieldID=a.find(".redux-color_rgba-container").data("id")},redux.field_objects.color_rgba.initColorPicker=function(b){var c=redux.field_objects.color_rgba.fieldID,d=b.find(".redux-color-rgba"),e=d.data("current-alpha");e=Number(null===e||void 0===e?1:e);var f=d.data("current-color");f=""===f||"transparent"===f?"":f;var g=d.data("output-transparent");g=Boolean(""===g?!1:g);var h=b.find(".redux-color-rgba-container"),i=h.data("palette");i=decodeURIComponent(i),i=JSON.parse(i),null===i&&(i=[["#000000","#434343","#666666","#999999","#b7b7b7","#cccccc","#d9d9d9","#efefef","#f3f3f3","#ffffff"],["#980000","#ff0000","#ff9900","#ffff00","#00ff00","#00ffff","#4a86e8","#0000ff","#9900ff","#ff00ff"],["#e6b8af","#f4cccc","#fce5cd","#fff2cc","#d9ead3","#d9ead3","#c9daf8","#cfe2f3","#d9d2e9","#ead1dc"],["#dd7e6b","#ea9999","#f9cb9c","#ffe599","#b6d7a8","#a2c4c9","#a4c2f4","#9fc5e8","#b4a7d6","#d5a6bd"],["#cc4125","#e06666","#f6b26b","#ffd966","#93c47d","#76a5af","#6d9eeb","#6fa8dc","#8e7cc3","#c27ba0"],["#a61c00","#cc0000","#e69138","#f1c232","#6aa84f","#45818e","#3c78d8","#3d85c6","#674ea7","#a64d79"],["#85200c","#990000","#b45f06","#bf9000","#38761d","#134f5c","#1155cc","#0b5394","#351c75","#741b47"],["#5b0f00","#660000","#783f04","#7f6000","#274e13","#0c343d","#1c4587","#073763","#20124d","#4c1130"]]);var j=h.data("show-input");j=Boolean(""===j?!1:j);var k=h.data("show-initial");k=Boolean(""===k?!1:k);var l=h.data("show-alpha");l=Boolean(""===l?!1:l);var m=h.data("allow-empty");m=Boolean(""===m?!1:m);var n=h.data("show-palette");n=Boolean(""===n?!1:n);var o=h.data("show-palette-only");o=Boolean(""===o?!1:o);var p=h.data("show-selection-palette");p=Boolean(""===p?!1:p);var q=Number(h.data("max-palette-size")),r=h.data("clickout-fires-change");r=Boolean(""===r?!1:r);var s=String(h.data("choose-text")),t=String(h.data("cancel-text")),u=String(h.data("input-text")),v=h.data("show-buttons");v=Boolean(""===v?!1:v);var w=String(h.data("container-class")),x=String(h.data("replacer-class"));d.spectrum({color:f,showAlpha:l,showInput:j,allowEmpty:m,className:"redux-color-rgba",showInitial:k,showPalette:n,showSelectionPalette:p,maxPaletteSize:q,showPaletteOnly:o,clickoutFiresChange:r,chooseText:s,cancelText:t,showButtons:v,containerClassName:w,replacerClassName:x,preferredFormat:"hex6",localStorageKey:"redux.color-rgba."+c,palette:i,inputText:u,change:function(c){var d,e,f;null===c?(d=g===!0?"transparent":null,e=null):(d=c.toHexString(),e=c.alpha),f="transparent"!=d?redux.field_objects.color_rgba.hexToRGBA(d,e):"transparent";var h=a(this).data("block-id");b.find("input#"+h+"-color").val(d),b.find("input#"+h+"-alpha").val(e),b.find("input#"+h+"-rgba").val(f),redux_change(b.find(".redux-color-rgba-container"))}})}}(jQuery); \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/color_rgba/field_color_rgba.php b/library/admin/ReduxCore/inc/fields/color_rgba/field_color_rgba.php deleted file mode 100644 index 65d56d8b..00000000 --- a/library/admin/ReduxCore/inc/fields/color_rgba/field_color_rgba.php +++ /dev/null @@ -1,291 +0,0 @@ -. - * - * @package Redux Framework - * @subpackage Spectrum Color Picker - * @author Kevin Provance (kprovance) - * @version 1.0.0 - */ - -// Exit if accessed directly -if( !defined( 'ABSPATH' ) ) { - exit; -} - -// Don't duplicate me! -if( !class_exists( 'ReduxFramework_color_rgba' ) ) { - - /** - * Main ReduxFramework_color_rgba class - * - * @since 1.0.0 - */ - class ReduxFramework_color_rgba { - - /** - * Class Constructor. Defines the args for the extions class - * - * @since 1.0.0 - * @access public - * @param array $field Field sections. - * @param array $value Values. - * @param array $parent Parent object. - * @return void - */ - public function __construct( $field = array(), $value ='', $parent ) { - - // Set required variables - $this->parent = $parent; - $this->field = $field; - $this->value = $value; - - $defaults = array( - 'color' => '', - 'alpha' => 1, - 'rgba' => '' - ); - - $this->value = wp_parse_args( $this->value, $defaults ); - - $this->field['options']['show_input'] = isset($this->field['options']['show_input']) ? $this->field['options']['show_input'] : true; - $this->field['options']['show_initial'] = isset($this->field['options']['show_initial']) ? $this->field['options']['show_initial'] : false; - $this->field['options']['show_alpha'] = isset($this->field['options']['show_alpha']) ? $this->field['options']['show_alpha'] : true; - $this->field['options']['show_palette'] = isset($this->field['options']['show_palette']) ? $this->field['options']['show_palette'] : false; - $this->field['options']['show_palette_only'] = isset($this->field['options']['show_palette_only']) ? $this->field['options']['show_palette_only'] : false; - $this->field['options']['max_palette_size'] = isset($this->field['options']['max_palette_size']) ? $this->field['options']['max_palette_size'] : 10; - $this->field['options']['show_selection_palette'] = isset($this->field['options']['show_selection_palette']) ? $this->field['options']['show_selection_palette'] : false; - $this->field['options']['allow_empty'] = isset($this->field['options']['allow_empty']) ? $this->field['options']['allow_empty'] : true; - $this->field['options']['clickout_fires_change'] = isset($this->field['options']['clickout_fires_change']) ? $this->field['options']['clickout_fires_change'] : false; - $this->field['options']['choose_text'] = isset($this->field['options']['choose_text']) ? $this->field['options']['choose_text'] : 'Choose'; - $this->field['options']['cancel_text'] = isset($this->field['options']['cancel_text']) ? $this->field['options']['cancel_text'] : 'Cancel'; - $this->field['options']['show_buttons'] = isset($this->field['options']['show_buttons']) ? $this->field['options']['show_buttons'] : true; - $this->field['options']['palette'] = isset($this->field['options']['palette']) ? $this->field['options']['palette'] : null; - $this->field['options']['input_text'] = isset($this->field['options']['input_text']) ? $this->field['options']['input_text'] : 'Select Color'; - - // Convert empty array to null, if there. - $this->field['options']['palette'] = empty($this->field['options']['palette']) ? null : $this->field['options']['palette']; - - $this->field['output_transparent'] = isset($this->field['output_transparent']) ? $this->field['output_transparent'] : false; - } - - - /** - * Field Render Function. - * - * Takes the vars and outputs the HTML for the field in the settings - * - * @since 1.0.0 - * @access public - * @return void - */ - public function render() { - - $field_id = $this->field['id']; - - // Color picker container - echo '
    '; - - // Colour picker layout - $opt_name = $this->parent->args['opt_name']; - - if ('' == $this->value['color'] || 'transparent' == $this->value['color']) { - $color = ''; - } else { - $color = Redux_Helpers::hex2rgba($this->value['color'], $this->value['alpha']); - } - - if ($this->value['rgba'] == ''){ - $this->value['rgba'] = Redux_Helpers::hex2rgba($this->value['color'], $this->value['alpha']); - } - - echo ''; - - echo ''; - - // Hidden input for alpha channel - echo ''; - - // Hidden input for rgba - echo ''; - - echo '
    '; - } - - /** - * Enqueue Function. - * - * If this field requires any scripts, or css define this function and register/enqueue the scripts/css - * - * @since 1.0.0 - * @access public - * @return void - */ - public function enqueue() { - - // Set up min files for dev_mode = false. - $min = Redux_Functions::isMin(); - - // Field dependent JS - if (!wp_script_is ( 'redux-field-color-rgba-js' )) { - wp_enqueue_script( - 'redux-field-color-rgba-js', - ReduxFramework::$_url . 'inc/fields/color_rgba/field_color_rgba' . Redux_Functions::isMin() . '.js', - array('jquery', 'redux-spectrum-js'), - time(), - true - ); - } - - // Spectrum CSS - if (!wp_style_is ( 'redux-spectrum-css' )) { - wp_enqueue_style('redux-spectrum-css'); - } - - if ($this->parent->args['dev_mode']) { - if (!wp_style_is ( 'redux-field-color-rgba-css' )) { - wp_enqueue_style( - 'redux-field-color-rgba-css', - ReduxFramework::$_url . 'inc/fields/color_rgba/field_color_rgba.css', - array(), - time(), - 'all' - ); - } - } - } - - /** - * getColorVal. Returns formatted color val in hex or rgba. - * - * If this field requires any scripts, or css define this function and register/enqueue the scripts/css - * - * @since 1.0.0 - * @access private - * @return string - */ - private function getColorVal(){ - - // No notices - $color = ''; - $alpha = 1; - $rgba = ''; - - // Must be an array - if (is_array($this->value)) { - - // Enum array to parse values - foreach($this->value as $id => $val) { - - // Sanitize alpha - if ($id == 'alpha') { - $alpha = !empty($val) ? $val : 1; - } elseif ($id == 'color') { - $color = !empty($val) ? $val : ''; - } elseif ($id == 'rgba') { - $rgba = !empty($val) ? $val : ''; - $rgba = Redux_Helpers::hex2rgba($color, $alpha); - } - } - - // Only build rgba output if alpha ia less than 1 - if ( $alpha < 1 && $alpha <> '' ) { - $color = $rgba; - } - } - - return $color; - } - - /** - * Output Function. - * - * Used to enqueue to the front-end - * - * @since 1.0.0 - * @access public - * @return void - */ - public function output() { - if (!empty($this->value)) { - $style = ''; - - $mode = ( isset( $this->field['mode'] ) && ! empty( $this->field['mode'] ) ? $this->field['mode'] : 'color' ); - - $color_val = $this->getColorVal(); - - $style .= $mode . ':' . $color_val . ';'; - - if ( ! empty( $this->field['output'] ) && is_array( $this->field['output'] ) ) { - $css = Redux_Functions::parseCSS( $this->field['output'], $style, $color_val ); - $this->parent->outputCSS .= $css; - } - - if ( ! empty( $this->field['compiler'] ) && is_array( $this->field['compiler'] ) ) { - $css = Redux_Functions::parseCSS( $this->field['compiler'], $style, $color_val ); - $this->parent->compilerCSS .= $css ; - } - } - } - } -} diff --git a/library/admin/ReduxCore/inc/fields/color_rgba/field_color_rgba.scss b/library/admin/ReduxCore/inc/fields/color_rgba/field_color_rgba.scss deleted file mode 100644 index 6c328697..00000000 --- a/library/admin/ReduxCore/inc/fields/color_rgba/field_color_rgba.scss +++ /dev/null @@ -1,61 +0,0 @@ -.sp-container { -/* border: solid 1px black; - -webkit-box-shadow: inset 0 2px 5px -3px rgba(0, 0, 0, 0.5), 0 0 0 1px #5b9dd9, 0 0 2px 1px rgba(30, 140, 190, 0.8); - box-shadow: inset 0 2px 5px -3px rgba(0, 0, 0, 0.5), 0 0 0 1px #5b9dd9, 0 0 2px 1px rgba(30, 140, 190, 0.8);*/ - color: #555; - border-color: #cccccc; - background: #f7f7f7; - -webkit-box-shadow: inset 0 1px 0 #fff, 0 1px 0 rgba( 0, 0, 0, 0.08 ); - box-shadow: inset 0 1px 0 #fff, 0 1px 0 rgba( 0, 0, 0, 0.08 ); - vertical-align: top; -} - -.sp-replacer { - color: #555; - border-color: #cccccc; - background: #f7f7f7; - -webkit-box-shadow: inset 0 1px 0 #fff, 0 1px 0 rgba( 0, 0, 0, 0.08 ); - box-shadow: inset 0 1px 0 #fff, 0 1px 0 rgba( 0, 0, 0, 0.08 ); - vertical-align: top; -} - -.sp-replacer:focus, -.sp-replacer:hover, -.sp-replacer.focus, -.sp-replacer.hover { - background: #fafafa; - border-color: #999; - color: #222; -} - -.sp-replacer:focus, -.sp-replacer.focus { - -webkit-box-shadow: - 0 0 0 1px #5b9dd9, - 0 0 2px 1px rgba(30, 140, 190, .8); - box-shadow: - 0 0 0 1px #5b9dd9, - 0 0 2px 1px rgba(30, 140, 190, .8); - -} - -.sp-replacer.active:focus { - -webkit-box-shadow: - inset 0 2px 5px -3px rgba( 0, 0, 0, 0.5 ), - 0 0 0 1px #5b9dd9, - 0 0 2px 1px rgba(30, 140, 190, .8); - box-shadow: - inset 0 2px 5px -3px rgba( 0, 0, 0, 0.5 ), - 0 0 0 1px #5b9dd9, - 0 0 2px 1px rgba(30, 140, 190, .8); -} - -.sp-replacer.active, -.sp-replacer.active:hover, -.sp-replacer:active{ - background: #eee; - border-color: #999; - color: #333; - -webkit-box-shadow: inset 0 2px 5px -3px rgba( 0, 0, 0, 0.5 ); - box-shadow: inset 0 2px 5px -3px rgba( 0, 0, 0, 0.5 ); -} \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/date/field_date.css b/library/admin/ReduxCore/inc/fields/date/field_date.css deleted file mode 100644 index ac4c4d42..00000000 --- a/library/admin/ReduxCore/inc/fields/date/field_date.css +++ /dev/null @@ -1 +0,0 @@ -#ui-datepicker-div{z-index:15 !important}.ui-datepicker-header{background-color:#00abef} diff --git a/library/admin/ReduxCore/inc/fields/date/field_date.js b/library/admin/ReduxCore/inc/fields/date/field_date.js deleted file mode 100644 index f39c473e..00000000 --- a/library/admin/ReduxCore/inc/fields/date/field_date.js +++ /dev/null @@ -1,82 +0,0 @@ -/*global jQuery, document, redux*/ - -(function( $ ) { - "use strict"; - - redux.field_objects = redux.field_objects || {}; - redux.field_objects.date = redux.field_objects.date || {}; - - $( document ).ready( - function() { - //redux.field_objects.date.init(); - } - ); - - redux.field_objects.date.init = function( selector ) { - if ( !selector ) { - selector = $( document ).find( '.redux-container-date:visible' ); - } - $( selector ).each( - function() { - var el = $( this ); - var parent = el; - if ( !el.hasClass( 'redux-field-container' ) ) { - parent = el.parents( '.redux-field-container:first' ); - } - if ( parent.is( ":hidden" ) ) { // Skip hidden fields - return; - } - if ( parent.hasClass( 'redux-field-init' ) ) { - parent.removeClass( 'redux-field-init' ); - } else { - return; - } -// var someArr = [] -// someArr = i; -// console.log(someArr); - -// var str = JSON.parse('{"redux_demo[opt-multi-check]":{"redux_demo[opt-multi-check][1]":"1","redux_demo[opt-multi-check][2]":"","redux_demo[opt-multi-check][3]":""}}'); -// console.log (str); -// -// $.each(str, function(idx, val){ -// var tmpArr = new Object(); -// var count = 1; -// -// $.each(val, function (i, v){ -// -// tmpArr[count] = v; -// count++; -// }); -// -// var newArr = {}; -// newArr[idx] = tmpArr; -// var newJSON = JSON.stringify(newArr) -// //console.log(newJSON); -// }); - - el.find( '.redux-datepicker' ).each( function() { - - $( this ).datepicker({ - beforeShow: function(input, instance){ - var el = $('#ui-datepicker-div'); - //$.datepicker._pos = $.datepicker._findPos(input); //this is the default position - var popover = instance.dpDiv; - $('.redux-container:first').append(el); - $('#ui-datepicker-div').hide(); - setTimeout(function() { - popover.position({ - my: 'left top', - at: 'left bottom', - collision: 'none', - of: input - }); - }, 1); - } - }); - }); - } - ); - - - }; -})( jQuery ); \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/date/field_date.min.js b/library/admin/ReduxCore/inc/fields/date/field_date.min.js deleted file mode 100644 index 60e51379..00000000 --- a/library/admin/ReduxCore/inc/fields/date/field_date.min.js +++ /dev/null @@ -1 +0,0 @@ -!function(a){"use strict";redux.field_objects=redux.field_objects||{},redux.field_objects.date=redux.field_objects.date||{},a(document).ready(function(){}),redux.field_objects.date.init=function(b){b||(b=a(document).find(".redux-container-date:visible")),a(b).each(function(){var b=a(this),c=b;b.hasClass("redux-field-container")||(c=b.parents(".redux-field-container:first")),c.is(":hidden")||c.hasClass("redux-field-init")&&(c.removeClass("redux-field-init"),b.find(".redux-datepicker").each(function(){a(this).datepicker({beforeShow:function(b,c){var d=a("#ui-datepicker-div"),e=c.dpDiv;a(".redux-container:first").append(d),a("#ui-datepicker-div").hide(),setTimeout(function(){e.position({my:"left top",at:"left bottom",collision:"none",of:b})},1)}})}))})}}(jQuery); \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/date/field_date.php b/library/admin/ReduxCore/inc/fields/date/field_date.php deleted file mode 100644 index ad532527..00000000 --- a/library/admin/ReduxCore/inc/fields/date/field_date.php +++ /dev/null @@ -1,95 +0,0 @@ -. - * - * @package ReduxFramework - * @subpackage Field_Date - * @author Daniel J Griffiths (Ghost1227) - * @author Dovy Paukstys - * @author Kevin Provance (kprovance) - * @version 3.0.0 - */ - -// Exit if accessed directly -if ( ! defined( 'ABSPATH' ) ) { - exit; -} - -// Don't duplicate me! -if ( ! class_exists( 'ReduxFramework_date' ) ) { - - /** - * Main ReduxFramework_date class - * - * @since 1.0.0 - */ - class ReduxFramework_date { - - /** - * Field Constructor. - * Required - must call the parent constructor, then assign field and value to vars, and obviously call the render field function - * - * @since 1.0.0 - * @access public - * @return void - */ - function __construct( $field = array(), $value = '', $parent ) { - $this->parent = $parent; - $this->field = $field; - $this->value = $value; - } - - /** - * Field Render Function. - * Takes the vars and outputs the HTML for the field in the settings - * - * @since 1.0.0 - * @access public - * @return void - */ - public function render() { - $placeholder = ( isset( $this->field['placeholder'] ) ) ? ' placeholder="' . esc_attr( $this->field['placeholder'] ) . '" ' : ''; - - echo ''; - } - - /** - * Enqueue Function. - * If this field requires any scripts, or css define this function and register/enqueue the scripts/css - * - * @since 1.0.0 - * @access public - * @return void - */ - public function enqueue() { - - if ($this->parent->args['dev_mode']) { - wp_enqueue_style( - 'redux-field-date-css', - ReduxFramework::$_url . 'inc/fields/date/field_date.css', - array(), - time(), - 'all' - ); - } - - wp_enqueue_script( - 'redux-field-date-js', - ReduxFramework::$_url . 'inc/fields/date/field_date' . Redux_Functions::isMin() . '.js', - array( 'jquery', 'jquery-ui-core', 'jquery-ui-datepicker', 'redux-js' ), - time(), - true - ); - } - } -} \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/date/field_date.scss b/library/admin/ReduxCore/inc/fields/date/field_date.scss deleted file mode 100644 index dd931de6..00000000 --- a/library/admin/ReduxCore/inc/fields/date/field_date.scss +++ /dev/null @@ -1,8 +0,0 @@ -#ui-datepicker-div { - z-index: 15 !important; -} - -.ui-datepicker-header { - background-color: #00abef; -} - diff --git a/library/admin/ReduxCore/inc/fields/dimensions/field_dimensions.css b/library/admin/ReduxCore/inc/fields/dimensions/field_dimensions.css deleted file mode 100644 index 9b0cbf92..00000000 --- a/library/admin/ReduxCore/inc/fields/dimensions/field_dimensions.css +++ /dev/null @@ -1 +0,0 @@ -.redux-dimensions-container select,.redux-dimensions-container .select_wrapper{width:65px !important;float:left}.redux-dimensions-container .field-dimensions-input{margin-right:10px;margin-bottom:7px}@media screen and (max-width: 782px){.redux-dimensions-container .field-dimensions-input input{display:inline-block !important;width:100px !important}.redux-dimensions-container .field-dimensions-input .add-on{padding:7px 4px;font-size:16px;line-height:1.5}.redux-dimensions-container .select_wrapper{margin-top:6px}} diff --git a/library/admin/ReduxCore/inc/fields/dimensions/field_dimensions.js b/library/admin/ReduxCore/inc/fields/dimensions/field_dimensions.js deleted file mode 100644 index 3ddc6f18..00000000 --- a/library/admin/ReduxCore/inc/fields/dimensions/field_dimensions.js +++ /dev/null @@ -1,76 +0,0 @@ - -/*global jQuery, document, redux*/ - -(function( $ ) { - "use strict"; - - redux.field_objects = redux.field_objects || {}; - redux.field_objects.dimensions = redux.field_objects.dimensions || {}; - - $( document ).ready( - function() { - //redux.field_objects.dimensions.init(); - } - ); - - redux.field_objects.dimensions.init = function( selector ) { - - if ( !selector ) { - selector = $( document ).find( '.redux-container-dimensions:visible' ); - } - $( selector ).each( - function() { - var el = $( this ); - var parent = el; - if ( !el.hasClass( 'redux-field-container' ) ) { - parent = el.parents( '.redux-field-container:first' ); - } - if ( parent.is( ":hidden" ) ) { // Skip hidden fields - return; - } - if ( parent.hasClass( 'redux-field-init' ) ) { - parent.removeClass( 'redux-field-init' ); - } else { - return; - } - var default_params = { - width: 'resolve', - triggerChange: true, - allowClear: true - }; - - var select2_handle = el.find( '.select2_params' ); - if ( select2_handle.size() > 0 ) { - var select2_params = select2_handle.val(); - - select2_params = JSON.parse( select2_params ); - default_params = $.extend( {}, default_params, select2_params ); - } - - el.find( ".redux-dimensions-units" ).select2( default_params ); - - el.find( '.redux-dimensions-input' ).on( - 'change', function() { - var units = $( this ).parents( '.redux-field:first' ).find( '.field-units' ).val(); - if ( $( this ).parents( '.redux-field:first' ).find( '.redux-dimensions-units' ).length !== 0 ) { - units = $( this ).parents( '.redux-field:first' ).find( '.redux-dimensions-units option:selected' ).val(); - } - if ( typeof units !== 'undefined' ) { - el.find( '#' + $( this ).attr( 'rel' ) ).val( $( this ).val() + units ); - } else { - el.find( '#' + $( this ).attr( 'rel' ) ).val( $( this ).val() ); - } - } - ); - - el.find( '.redux-dimensions-units' ).on( - 'change', function() { - $( this ).parents( '.redux-field:first' ).find( '.redux-dimensions-input' ).change(); - } - ); - } - ); - - - }; -})( jQuery ); \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/dimensions/field_dimensions.less b/library/admin/ReduxCore/inc/fields/dimensions/field_dimensions.less deleted file mode 100644 index 41fca0ef..00000000 --- a/library/admin/ReduxCore/inc/fields/dimensions/field_dimensions.less +++ /dev/null @@ -1,30 +0,0 @@ -.redux-dimensions-container { - select, .select_wrapper { - width: 80px !important; - float: left; - } - - .field-dimensions-input { - margin-right: 10px; - margin-bottom: 7px; - } -} - -@media screen and (max-width: 782px) { - .redux-dimensions-container { - .field-dimensions-input { - input { - display: inline-block !important; - width: 100px !important; - } - .add-on { - padding: 7px 4px; - font-size: 16px; - line-height: 1.5; - } - } - .select_wrapper { - margin-top: 6px; - } - } -} \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/dimensions/field_dimensions.min.js b/library/admin/ReduxCore/inc/fields/dimensions/field_dimensions.min.js deleted file mode 100644 index d675d29c..00000000 --- a/library/admin/ReduxCore/inc/fields/dimensions/field_dimensions.min.js +++ /dev/null @@ -1 +0,0 @@ -!function(a){"use strict";redux.field_objects=redux.field_objects||{},redux.field_objects.dimensions=redux.field_objects.dimensions||{},a(document).ready(function(){}),redux.field_objects.dimensions.init=function(b){b||(b=a(document).find(".redux-container-dimensions:visible")),a(b).each(function(){var b=a(this),c=b;if(b.hasClass("redux-field-container")||(c=b.parents(".redux-field-container:first")),!c.is(":hidden")&&c.hasClass("redux-field-init")){c.removeClass("redux-field-init");var d={width:"resolve",triggerChange:!0,allowClear:!0},e=b.find(".select2_params");if(e.size()>0){var f=e.val();f=JSON.parse(f),d=a.extend({},d,f)}b.find(".redux-dimensions-units").select2(d),b.find(".redux-dimensions-input").on("change",function(){var c=a(this).parents(".redux-field:first").find(".field-units").val();0!==a(this).parents(".redux-field:first").find(".redux-dimensions-units").length&&(c=a(this).parents(".redux-field:first").find(".redux-dimensions-units option:selected").val()),"undefined"!=typeof c?b.find("#"+a(this).attr("rel")).val(a(this).val()+c):b.find("#"+a(this).attr("rel")).val(a(this).val())}),b.find(".redux-dimensions-units").on("change",function(){a(this).parents(".redux-field:first").find(".redux-dimensions-input").change()})}})}}(jQuery); \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/dimensions/field_dimensions.php b/library/admin/ReduxCore/inc/fields/dimensions/field_dimensions.php deleted file mode 100644 index 317c66b7..00000000 --- a/library/admin/ReduxCore/inc/fields/dimensions/field_dimensions.php +++ /dev/null @@ -1,306 +0,0 @@ -parent = $parent; - $this->field = $field; - $this->value = $value; - } //function - - /** - * Field Render Function. - * Takes the vars and outputs the HTML for the field in the settings - * - * @since ReduxFramework 1.0.0 - */ - function render() { - - /* - * So, in_array() wasn't doing it's job for checking a passed array for a proper value. - * It's wonky. It only wants to check the keys against our array of acceptable values, and not the key's - * value. So we'll use this instead. Fortunately, a single no array value can be passed and it won't - * take a dump. - */ - - // No errors please - $defaults = array( - 'width' => true, - 'height' => true, - 'units_extended' => false, - 'units' => 'px', - 'mode' => array( - 'width' => false, - 'height' => false, - ), - ); - - $this->field = wp_parse_args( $this->field, $defaults ); - - $defaults = array( - 'width' => '', - 'height' => '', - 'units' => 'px' - ); - - $this->value = wp_parse_args( $this->value, $defaults ); - - if ( isset( $this->value['unit'] ) ) { - $this->value['units'] = $this->value['unit']; - } - - /* - * Acceptable values checks. If the passed variable doesn't pass muster, we unset them - * and reset them with default values to avoid errors. - */ - - // If units field has a value but is not an acceptable value, unset the variable - if ( isset( $this->field['units'] ) && ! Redux_Helpers::array_in_array( $this->field['units'], array( - '', - false, - '%', - 'in', - 'cm', - 'mm', - 'em', - 'ex', - 'pt', - 'pc', - 'px', - 'rem' - ) ) - ) { - unset( $this->field['units'] ); - } - - //if there is a default unit value but is not an accepted value, unset the variable - if ( isset( $this->value['units'] ) && ! Redux_Helpers::array_in_array( $this->value['units'], array( - '', - '%', - 'in', - 'cm', - 'mm', - 'em', - 'ex', - 'pt', - 'pc', - 'px' - ) ) - ) { - unset( $this->value['units'] ); - } - - /* - * Since units field could be an array, string value or bool (to hide the unit field) - * we need to separate our functions to avoid those nasty PHP index notices! - */ - - // if field units has a value and IS an array, then evaluate as needed. - if ( isset( $this->field['units'] ) && ! is_array( $this->field['units'] ) ) { - - //if units fields has a value but units value does not then make units value the field value - if ( isset( $this->field['units'] ) && ! isset( $this->value['units'] ) || $this->field['units'] == false ) { - $this->value['units'] = $this->field['units']; - - // If units field does NOT have a value and units value does NOT have a value, set both to blank (default?) - } else if ( ! isset( $this->field['units'] ) && ! isset( $this->value['units'] ) ) { - $this->field['units'] = 'px'; - $this->value['units'] = 'px'; - - // If units field has NO value but units value does, then set unit field to value field - } else if ( ! isset( $this->field['units'] ) && isset( $this->value['units'] ) ) { - $this->field['units'] = $this->value['units']; - - // if unit value is set and unit value doesn't equal unit field (coz who knows why) - // then set unit value to unit field - } elseif ( isset( $this->value['units'] ) && $this->value['units'] !== $this->field['units'] ) { - $this->value['units'] = $this->field['units']; - } - - // do stuff based on unit field NOT set as an array - } elseif ( isset( $this->field['units'] ) && is_array( $this->field['units'] ) ) { - // nothing to do here, but I'm leaving the construct just in case I have to debug this again. - } - - echo '
    '; - - if ( isset( $this->field['select2'] ) ) { // if there are any let's pass them to js - $select2_params = json_encode( $this->field['select2'] ); - $select2_params = htmlspecialchars( $select2_params, ENT_QUOTES ); - - echo ''; - } - - - // This used to be unit field, but was giving the PHP index error when it was an array, - // so I changed it. - echo ''; - - /** - * Width - * */ - if ( $this->field['width'] === true ) { - if ( ! empty( $this->value['width'] ) && strpos( $this->value['width'], $this->value['units'] ) === false ) { - $this->value['width'] = filter_var( $this->value['width'], FILTER_SANITIZE_NUMBER_FLOAT, FILTER_FLAG_ALLOW_FRACTION ); - if ( $this->field['units'] !== false ) { - $this->value['width'] .= $this->value['units']; - } - } - echo '
    '; - echo ''; - echo ''; - echo '
    '; - } - - /** - * Height - * */ - if ( $this->field['height'] === true ) { - if ( ! empty( $this->value['height'] ) && strpos( $this->value['height'], $this->value['units'] ) === false ) { - $this->value['height'] = filter_var( $this->value['height'], FILTER_SANITIZE_NUMBER_FLOAT, FILTER_FLAG_ALLOW_FRACTION ); - if ( $this->field['units'] !== false ) { - $this->value['height'] .= $this->value['units']; - } - } - echo '
    '; - echo ''; - echo ''; - echo '
    '; - } - - /** - * Units - * */ - // If units field is set and units field NOT false then - // fill out the options object and show it, otherwise it's hidden - // and the default units value will apply. - if ( isset( $this->field['units'] ) && $this->field['units'] !== false ) { - echo '
    '; - echo '
    '; - }; - echo "
    "; - } //function - - /** - * Enqueue Function. - * If this field requires any scripts, or css define this function and register/enqueue the scripts/css - * - * @since ReduxFramework 1.0.0 - */ - function enqueue() { - wp_enqueue_style( 'select2-css' ); - - wp_enqueue_script( - 'redux-field-dimensions-js', - ReduxFramework::$_url . 'inc/fields/dimensions/field_dimensions' . Redux_Functions::isMin() . '.js', - array( 'jquery', 'select2-js', 'redux-js' ), - time(), - true - ); - - if ( $this->parent->args['dev_mode'] ) { - wp_enqueue_style( - 'redux-field-dimensions-css', - ReduxFramework::$_url . 'inc/fields/dimensions/field_dimensions.css', - array(), - time(), - 'all' - ); - } - } - - public function output() { - - // if field units has a value and IS an array, then evaluate as needed. - if ( isset( $this->field['units'] ) && ! is_array( $this->field['units'] ) ) { - - //if units fields has a value but units value does not then make units value the field value - if ( isset( $this->field['units'] ) && ! isset( $this->value['units'] ) || $this->field['units'] == false ) { - $this->value['units'] = $this->field['units']; - - // If units field does NOT have a value and units value does NOT have a value, set both to blank (default?) - } else if ( ! isset( $this->field['units'] ) && ! isset( $this->value['units'] ) ) { - $this->field['units'] = 'px'; - $this->value['units'] = 'px'; - - // If units field has NO value but units value does, then set unit field to value field - } else if ( ! isset( $this->field['units'] ) && isset( $this->value['units'] ) ) { - $this->field['units'] = $this->value['units']; - - // if unit value is set and unit value doesn't equal unit field (coz who knows why) - // then set unit value to unit field - } elseif ( isset( $this->value['units'] ) && $this->value['units'] !== $this->field['units'] ) { - $this->value['units'] = $this->field['units']; - } - - // do stuff based on unit field NOT set as an array - } elseif ( isset( $this->field['units'] ) && is_array( $this->field['units'] ) ) { - // nothing to do here, but I'm leaving the construct just in case I have to debug this again. - } - - $units = isset( $this->value['units'] ) ? $this->value['units'] : ""; - - $height = isset( $this->field['mode'] ) && ! empty( $this->field['mode'] ) ? $this->field['mode'] : 'height'; - $width = isset( $this->field['mode'] ) && ! empty( $this->field['mode'] ) ? $this->field['mode'] : 'width'; - - $cleanValue = array( - $height => isset( $this->value['height'] ) ? filter_var( $this->value['height'], FILTER_SANITIZE_NUMBER_FLOAT, FILTER_FLAG_ALLOW_FRACTION ) : '', - $width => isset( $this->value['width'] ) ? filter_var( $this->value['width'], FILTER_SANITIZE_NUMBER_FLOAT, FILTER_FLAG_ALLOW_FRACTION ) : '', - ); - - $style = ""; - - foreach ( $cleanValue as $key => $value ) { - // Output if it's a numeric entry - if ( isset( $value ) && is_numeric( $value ) ) { - $style .= $key . ':' . $value . $units . ';'; - } - } - - if ( ! empty( $style ) ) { - if ( ! empty( $this->field['output'] ) && is_array( $this->field['output'] ) ) { - $keys = implode( ",", $this->field['output'] ); - $this->parent->outputCSS .= $keys . "{" . $style . '}'; - } - - if ( ! empty( $this->field['compiler'] ) && is_array( $this->field['compiler'] ) ) { - $keys = implode( ",", $this->field['compiler'] ); - $this->parent->compilerCSS .= $keys . "{" . $style . '}'; - } - } - } //function - } //class - } - - diff --git a/library/admin/ReduxCore/inc/fields/dimensions/field_dimensions.scss b/library/admin/ReduxCore/inc/fields/dimensions/field_dimensions.scss deleted file mode 100644 index 2eb5dbe5..00000000 --- a/library/admin/ReduxCore/inc/fields/dimensions/field_dimensions.scss +++ /dev/null @@ -1,33 +0,0 @@ -.redux-dimensions-container { - select, - .select_wrapper { - width: 65px !important; - float: left; - } - - .field-dimensions-input { - margin-right: 10px; - margin-bottom: 7px; - } -} - -@media screen and (max-width: 782px) { - .redux-dimensions-container { - .field-dimensions-input { - input { - display: inline-block !important; - width: 100px !important; - } - - .add-on { - padding: 7px 4px; - font-size: 16px; - line-height: 1.5; - } - } - - .select_wrapper { - margin-top: 6px; - } - } -} \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/divide/field_divide.css b/library/admin/ReduxCore/inc/fields/divide/field_divide.css deleted file mode 100644 index 85e90f82..00000000 --- a/library/admin/ReduxCore/inc/fields/divide/field_divide.css +++ /dev/null @@ -1 +0,0 @@ -.redux-main .divide{height:20px;line-height:20px;float:none;border-color:#E7E7E7;display:block;width:100%;height:35px !important;line-height:35px !important;position:relative;margin:15px 0 10px 0}.redux-main .divide .inner{width:42% !important;left:40% !important;margin-left:-6%;background-color:#FCFCFC;border-color:#E7E7E7;position:absolute;height:1px;top:50%;width:100%;margin-top:-1px;border-top-width:1px;border-top-style:solid}.redux-main .divide .inner span{background-color:#FCFCFC;border-color:#E7E7E7;height:5px;width:5px;border-width:2px;border-style:solid;display:block;position:absolute;left:50%;margin-left:-5px;margin-top:-5px}.wp-customizer .redux-container-divide .divide .inner{width:82% !important;left:18% !important;margin-left:-8%} diff --git a/library/admin/ReduxCore/inc/fields/divide/field_divide.php b/library/admin/ReduxCore/inc/fields/divide/field_divide.php deleted file mode 100644 index d5e526d2..00000000 --- a/library/admin/ReduxCore/inc/fields/divide/field_divide.php +++ /dev/null @@ -1,85 +0,0 @@ -. - * - * @package ReduxFramework - * @subpackage Field_Divide - * @author Daniel J Griffiths (Ghost1227) - * @author Dovy Paukstys - * @version 3.0.0 - */ - -// Exit if accessed directly -if ( !defined ( 'ABSPATH' ) ) { - exit; -} - -// Don't duplicate me! -if ( !class_exists ( 'ReduxFramework_divide' ) ) { - - /** - * Main ReduxFramework_divide class - * - * @since 1.0.0 - */ - class ReduxFramework_divide { - - /** - * Field Constructor. - * Required - must call the parent constructor, then assign field and value to vars, and obviously call the render field function - * - * @since 1.0.0 - * @access public - * @return void - */ - function __construct ( $field = array(), $value = '', $parent ) { - $this->parent = $parent; - $this->field = $field; - $this->value = $value; - } - - /** - * Field Render Function. - * Takes the vars and outputs the HTML for the field in the settings - * - * @since 1.0.0 - * @access public - * @return void - */ - public function render () { - echo '
    '; - echo '
     
    '; - echo '
    '; - } - - /** - * Enqueue Function. - * If this field requires any scripts, or css define this function and register/enqueue the scripts/css - * - * @since 1.0.0 - * @access public - * @return void - */ - public function enqueue() { - if ($this->parent->args['dev_mode']) { - wp_enqueue_style( - 'redux-field-divide', - ReduxFramework::$_url . 'inc/fields/divide/field_divide.css', - array(), - time(), - 'all' - ); - } - } - } -} \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/divide/field_divide.scss b/library/admin/ReduxCore/inc/fields/divide/field_divide.scss deleted file mode 100644 index 2de5656b..00000000 --- a/library/admin/ReduxCore/inc/fields/divide/field_divide.scss +++ /dev/null @@ -1,50 +0,0 @@ -.redux-main { - .divide { - height: 20px; - line-height: 20px; - float: none; - border-color: #E7E7E7; - display: block; - width: 100%; - height: 35px !important; - line-height: 35px !important; - position: relative; - margin: 15px 0 10px 0; - - .inner { - width: 42% !important; - left: 40% !important; - margin-left: -6%; - background-color: #FCFCFC; - border-color: #E7E7E7; - position: absolute; - height: 1px; - top: 50%; - width: 100%; - margin-top: -1px; - border-top-width: 1px; - border-top-style: solid; - span { - background-color: #FCFCFC; - border-color: #E7E7E7; - height: 5px; - width: 5px; - border-width: 2px; - border-style: solid; - display: block; - position: absolute; - left: 50%; - margin-left: -5px; - margin-top: -5px; - } - } - } -} - -.wp-customizer .redux-container-divide { - .divide .inner { - width: 82% !important; - left: 18% !important; - margin-left: -8%; - } -} \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/editor/field_editor.css b/library/admin/ReduxCore/inc/fields/editor/field_editor.css deleted file mode 100644 index 735a0dbb..00000000 --- a/library/admin/ReduxCore/inc/fields/editor/field_editor.css +++ /dev/null @@ -1 +0,0 @@ -.redux-container-editor .mceLayout td{border-width:1px;margin:0;padding:1px}.redux-container-editor input,.redux-container-editor textarea{margin:inherit}.redux-container-editor textarea{border-style:none;border:0;border-width:0}.redux-container-editor .wp-editor-container{-webkit-border-radius:3px;-moz-border-radius:3px;border-radius:3px}.redux-container-editor .wp-editor-container textarea{-webkit-border-radius:0;-moz-border-radius:0;border-radius:0;border-style:inherit}.redux-container-editor .quicktags-toolbar input{margin:2px 1px 4px;line-height:18px;display:inline-block;min-width:26px;padding:2px 4px;font:12px/18px Arial, Helvetica, sans-serif normal;color:#464646;border:1px solid #c3c3c3;-webkit-border-radius:3px;border-radius:3px;background:#eee;background-image:-webkit-gradient(linear, left bottom, left top, from(#e3e3e3), to(#fff));background-image:-webkit-linear-gradient(bottom, #e3e3e3, #fff);background-image:-moz-linear-gradient(bottom, #e3e3e3, #fff);background-image:-o-linear-gradient(bottom, #e3e3e3, #fff);background-image:linear-gradient(to top, #e3e3e3, #fff)} diff --git a/library/admin/ReduxCore/inc/fields/editor/field_editor.js b/library/admin/ReduxCore/inc/fields/editor/field_editor.js deleted file mode 100644 index 26c514b3..00000000 --- a/library/admin/ReduxCore/inc/fields/editor/field_editor.js +++ /dev/null @@ -1,42 +0,0 @@ -/** - * Redux Editor on change callback - * Dependencies : jquery - * Feature added by : Dovy Paukstys - * : Kevin Provance (who helped) :P - * Date : 07 June 2014 - */ - -/*global redux_change, wp, tinymce, redux*/ -(function( $ ) { - "use strict"; - - redux.field_objects = redux.field_objects || {}; - redux.field_objects.editor = redux.field_objects.editor || {}; - - $( document ).ready( - function() { - //redux.field_objects.editor.init(); - } - ); - - redux.field_objects.editor.init = function( selector ) { - setTimeout( - function() { - for ( var i = 0; i < tinymce.editors.length; i++ ) { - redux.field_objects.editor.onChange( i ); - } - }, 1000 - ); - }; - - redux.field_objects.editor.onChange = function( i ) { - tinymce.editors[i].on( - 'change', function( e ) { - var el = jQuery( e.target.contentAreaContainer ); - if ( el.parents( '.redux-container-editor:first' ).length !== 0 ) { - redux_change( $( '.wp-editor-area' ) ); - } - } - ); - }; -})( jQuery ); diff --git a/library/admin/ReduxCore/inc/fields/editor/field_editor.min.js b/library/admin/ReduxCore/inc/fields/editor/field_editor.min.js deleted file mode 100644 index 3e41f956..00000000 --- a/library/admin/ReduxCore/inc/fields/editor/field_editor.min.js +++ /dev/null @@ -1 +0,0 @@ -!function(a){"use strict";redux.field_objects=redux.field_objects||{},redux.field_objects.editor=redux.field_objects.editor||{},a(document).ready(function(){}),redux.field_objects.editor.init=function(a){setTimeout(function(){for(var a=0;a. - * - * @package ReduxFramework - * @subpackage Field_Editor - * @author Daniel J Griffiths (Ghost1227) - * @author Dovy Paukstys - * @author Kevin Provance (kprovance) - * @version 3.0.0 - */ - -// Exit if accessed directly -if ( ! defined( 'ABSPATH' ) ) { - exit; -} - -// Don't duplicate me! -if ( ! class_exists( 'ReduxFramework_editor' ) ) { - - /** - * Main ReduxFramework_editor class - * - * @since 1.0.0 - */ - class ReduxFramework_editor { - - /** - * Field Constructor. - * Required - must call the parent constructor, then assign field and value to vars, and obviously call the render field function - * - * @since 1.0.0 - * @access public - * @return void - */ - function __construct( $field = array(), $value = '', $parent ) { - $this->parent = $parent; - $this->field = $field; - $this->value = $value; - } - - /** - * Field Render Function. - * Takes the vars and outputs the HTML for the field in the settings - * - * @since 1.0.0 - * @access public - * @return void - */ - public function render() { - - if ( ! isset( $this->field['args'] ) ) { - $this->field['args'] = array(); - } - - $this->field['args']['onchange_callback'] = "alert('here')"; - - // Setup up default args - $defaults = array( - 'textarea_name' => $this->field['name'] . $this->field['name_suffix'], - 'editor_class' => $this->field['class'], - 'textarea_rows' => 10, //Wordpress default - 'teeny' => true, - ); - - if ( isset( $this->field['editor_options'] ) && empty( $this->field['args'] ) ) { - $this->field['args'] = $this->field['editor_options']; - unset( $this->field['editor_options'] ); - } - - $this->field['args'] = wp_parse_args( $this->field['args'], $defaults ); - - wp_editor( $this->value, $this->field['id'], $this->field['args'] ); - } - - - /** - * Enqueue Function. - * If this field requires any scripts, or css define this function and register/enqueue the scripts/css - * - * @since 1.0.0 - * @access public - * @return void - */ - public function enqueue() { - if ($this->parent->args['dev_mode']) { - wp_enqueue_style( - 'redux-field-editor-css', - ReduxFramework::$_url . 'inc/fields/editor/field_editor.css', - array(), - time(), - 'all' - ); - } - - wp_enqueue_script( - 'redux-field-editor-js', - ReduxFramework::$_url . 'inc/fields/editor/field_editor' . Redux_Functions::isMin() . '.js', - array( 'jquery', 'redux-js' ), - time(), - true - ); - } - } -} \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/editor/field_editor.scss b/library/admin/ReduxCore/inc/fields/editor/field_editor.scss deleted file mode 100644 index 21aead3e..00000000 --- a/library/admin/ReduxCore/inc/fields/editor/field_editor.scss +++ /dev/null @@ -1,50 +0,0 @@ -.redux-container-editor { - .mceLayout td { - border-width: 1px; - margin: 0; - padding: 1px; - } - - input, - textarea { - margin: inherit; - } - - textarea { - border-style: none; - border: 0; - border-width: 0; - } - - .wp-editor-container { - -webkit-border-radius: 3px; - -moz-border-radius: 3px; - border-radius: 3px; - - textarea { - -webkit-border-radius: 0; - -moz-border-radius: 0; - border-radius: 0; - border-style: inherit; - } - } - - .quicktags-toolbar input { - margin: 2px 1px 4px; - line-height: 18px; - display: inline-block; - min-width: 26px; - padding: 2px 4px; - font: 12px/18px Arial, Helvetica, sans-serif normal; - color: #464646; - border: 1px solid #c3c3c3; - -webkit-border-radius: 3px; - border-radius: 3px; - background: #eee; - background-image: -webkit-gradient(linear, left bottom, left top, from(#e3e3e3), to(#fff)); - background-image: -webkit-linear-gradient(bottom, #e3e3e3, #fff); - background-image: -moz-linear-gradient(bottom, #e3e3e3, #fff); - background-image: -o-linear-gradient(bottom, #e3e3e3, #fff); - background-image: linear-gradient(to top, #e3e3e3, #fff); - } -} \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/editor/field_editor_c.php b/library/admin/ReduxCore/inc/fields/editor/field_editor_c.php deleted file mode 100644 index e69de29b..00000000 diff --git a/library/admin/ReduxCore/inc/fields/gallery/field_gallery.js b/library/admin/ReduxCore/inc/fields/gallery/field_gallery.js deleted file mode 100644 index a657477e..00000000 --- a/library/admin/ReduxCore/inc/fields/gallery/field_gallery.js +++ /dev/null @@ -1,110 +0,0 @@ -/* global redux_change, wp */ - -/*global redux_change, redux*/ - -(function( $ ) { - "use strict"; - - redux.field_objects = redux.field_objects || {}; - redux.field_objects.gallery = redux.field_objects.gallery || {}; - - $( document ).ready( - function() { - //redux.field_objects.gallery.init(); - } - ); - - redux.field_objects.gallery.init = function( selector ) { - - - if ( !selector ) { - selector = $( document ).find( '.redux-container-gallery:visible' ); - } - - $( selector ).each( - function() { - var el = $( this ); - var parent = el; - if ( !el.hasClass( 'redux-field-container' ) ) { - parent = el.parents( '.redux-field-container:first' ); - } - if ( parent.is( ":hidden" ) ) { // Skip hidden fields - return; - } - if ( parent.hasClass( 'redux-field-init' ) ) { - parent.removeClass( 'redux-field-init' ); - } else { - return; - } - // When the user clicks on the Add/Edit gallery button, we need to display the gallery editing - el.on( - { - click: function( event ) { - var current_gallery = $( this ).closest( 'fieldset' ); - - if ( event.currentTarget.id === 'clear-gallery' ) { - //remove value from input - - var rmVal = current_gallery.find( '.gallery_values' ).val( '' ); - - //remove preview images - current_gallery.find( ".screenshot" ).html( "" ); - - return; - - } - - // Make sure the media gallery API exists - if ( typeof wp === 'undefined' || !wp.media || !wp.media.gallery ) { - return; - } - event.preventDefault(); - - // Activate the media editor - var $$ = $( this ); - - var val = current_gallery.find( '.gallery_values' ).val(); - var final; - - if ( !val ) { - final = '[gallery ids="0"]'; - } else { - final = '[gallery ids="' + val + '"]'; - } - - var frame = wp.media.gallery.edit( final ); - - // When the gallery-edit state is updated, copy the attachment ids across - frame.state( 'gallery-edit' ).on( - 'update', function( selection ) { - - //clear screenshot div so we can append new selected images - current_gallery.find( ".screenshot" ).html( "" ); - - var element, preview_html = "", preview_img; - var ids = selection.models.map( - function( e ) { - element = e.toJSON(); - preview_img = typeof element.sizes.thumbnail !== 'undefined' ? element.sizes.thumbnail.url : element.url; - preview_html = ""; - current_gallery.find( ".screenshot" ).append( preview_html ); - - return e.id; - } - ); - - current_gallery.find( '.gallery_values' ).val( ids.join( ',' ) ); - redux_change( current_gallery.find( '.gallery_values' ) ); - - } - ); - - return false; - } - }, '.gallery-attachments' - ); - } - ); - - }; -})( jQuery ); \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/gallery/field_gallery.min.js b/library/admin/ReduxCore/inc/fields/gallery/field_gallery.min.js deleted file mode 100644 index 57680d02..00000000 --- a/library/admin/ReduxCore/inc/fields/gallery/field_gallery.min.js +++ /dev/null @@ -1 +0,0 @@ -!function(a){"use strict";redux.field_objects=redux.field_objects||{},redux.field_objects.gallery=redux.field_objects.gallery||{},a(document).ready(function(){}),redux.field_objects.gallery.init=function(b){b||(b=a(document).find(".redux-container-gallery:visible")),a(b).each(function(){var b=a(this),c=b;b.hasClass("redux-field-container")||(c=b.parents(".redux-field-container:first")),c.is(":hidden")||c.hasClass("redux-field-init")&&(c.removeClass("redux-field-init"),b.on({click:function(b){var c=a(this).closest("fieldset");if("clear-gallery"===b.currentTarget.id){c.find(".gallery_values").val("");return void c.find(".screenshot").html("")}if("undefined"!=typeof wp&&wp.media&&wp.media.gallery){b.preventDefault();var d,e=(a(this),c.find(".gallery_values").val());d=e?'[gallery ids="'+e+'"]':'[gallery ids="0"]';var f=wp.media.gallery.edit(d);return f.state("gallery-edit").on("update",function(a){c.find(".screenshot").html("");var b,d,e="",f=a.models.map(function(a){return b=a.toJSON(),d="undefined"!=typeof b.sizes.thumbnail?b.sizes.thumbnail.url:b.url,e="",c.find(".screenshot").append(e),a.id});c.find(".gallery_values").val(f.join(",")),redux_change(c.find(".gallery_values"))}),!1}}},".gallery-attachments"))})}}(jQuery); \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/gallery/field_gallery.php b/library/admin/ReduxCore/inc/fields/gallery/field_gallery.php deleted file mode 100644 index 116f780f..00000000 --- a/library/admin/ReduxCore/inc/fields/gallery/field_gallery.php +++ /dev/null @@ -1,105 +0,0 @@ -. - * - * @package ReduxFramework - * @subpackage Field_Gallery - * @author Abdullah Almesbahi (cadr-sa) - * @version 3.0.0 - */ - -// Exit if accessed directly -if ( ! defined( 'ABSPATH' ) ) { - exit; -} - -// Don't duplicate me! -if ( ! class_exists( 'ReduxFramework_gallery' ) ) { - - /** - * Main ReduxFramework_gallery class - * - * @since 3.0.0 - */ - class ReduxFramework_gallery { - - /** - * Field Constructor. - * Required - must call the parent constructor, then assign field and value to vars, and obviously call the render field function - * - * @since 1.0.0 - * @access public - * @return void - */ - function __construct( $field = array(), $value = '', $parent ) { - $this->parent = $parent; - $this->field = $field; - $this->value = $value; - } - - /** - * Field Render Function. - * Takes the vars and outputs the HTML for the field in the settings - * - * @since 1.0.0 - * @access public - * @return void - */ - public function render() { - echo '
    '; - - if ( ! empty( $this->value ) ) { - $ids = explode( ',', $this->value ); - - foreach ( $ids as $attachment_id ) { - $img = wp_get_attachment_image_src( $attachment_id, 'thumbnail' ); - echo ''; - echo ''; - echo ''; - } - } - - echo '
    '; - echo '' . __( 'Add/Edit Gallery', 'redux-framework' ) . ' '; - echo '' . __( 'Clear Gallery', 'redux-framework' ) . ''; - echo ''; - } - - /** - * Enqueue Function. - * If this field requires any scripts, or css define this function and register/enqueue the scripts/css - * - * @since 1.0.0 - * @access public - * @return void - */ - public function enqueue() { - - if ( function_exists( 'wp_enqueue_media' ) ) { - wp_enqueue_media(); - } else { - wp_enqueue_script( 'media-upload' ); - wp_enqueue_script( 'thickbox' ); - wp_enqueue_style( 'thickbox' ); - } - - wp_enqueue_script( - 'redux-field-gallery-js', - ReduxFramework::$_url . 'inc/fields/gallery/field_gallery' . Redux_Functions::isMin() . '.js', - array( 'jquery', 'redux-js' ), - time(), - true - ); - } - } -} \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/image_select/field_image_select.css b/library/admin/ReduxCore/inc/fields/image_select/field_image_select.css deleted file mode 100644 index 474f9346..00000000 --- a/library/admin/ReduxCore/inc/fields/image_select/field_image_select.css +++ /dev/null @@ -1 +0,0 @@ -.redux-container-image_select .redux-table-container{display:table;table-layout:fixed;width:100%}.redux-container-image_select .redux-image-select{margin:0 !important}.redux-container-image_select .redux-image-select .tiles{display:block;background-color:#FFF;background-repeat:repeat;width:40px;height:40px}.redux-container-image_select .redux-image-select img,.redux-container-image_select .redux-image-select .tiles{border-color:#d9d9d9}.redux-container-image_select .redux-image-select li:last-child{margin-bottom:0}.redux-container-image_select .redux-image-select input[type='radio']{display:none}.redux-container-image_select .redux-image-select-presets img{width:100%}.redux-container-image_select ul.redux-image-select li{margin:0 10px 3px 10px;display:inline-block;padding:2px 2px;padding-left:0}.redux-container-image_select .redux-image-select-selected{background-color:#f9f9f9}.redux-container-image_select .redux-image-select img,.redux-container-image_select .redux-image-select-selected img,.redux-container-image_select .redux-image-select .tiles,.redux-container-image_select .redux-image-select-selected .tiles{border-width:4px;border-style:solid}.redux-container-image_select .redux-image-select-selected .tiles,.redux-container-image_select .redux-image-select-selected .tiles{border-color:#7a7a7a} diff --git a/library/admin/ReduxCore/inc/fields/image_select/field_image_select.js b/library/admin/ReduxCore/inc/fields/image_select/field_image_select.js deleted file mode 100644 index ae209b39..00000000 --- a/library/admin/ReduxCore/inc/fields/image_select/field_image_select.js +++ /dev/null @@ -1,119 +0,0 @@ -/* global confirm, redux, redux_change */ - -/*global redux_change, redux*/ - -(function( $ ) { - "use strict"; - - redux.field_objects = redux.field_objects || {}; - redux.field_objects.image_select = redux.field_objects.image_select || {}; - - $( document ).ready( - function() { - //redux.field_objects.image_select.init(); - } - ); - - redux.field_objects.image_select.init = function( selector ) { - - if ( !selector ) { - selector = $( document ).find( ".redux-group-tab:visible" ).find( '.redux-container-image_select:visible' ); - } - - $( selector ).each( - function() { - var el = $( this ); - var parent = el; - if ( !el.hasClass( 'redux-field-container' ) ) { - parent = el.parents( '.redux-field-container:first' ); - } - if ( parent.is( ":hidden" ) ) { // Skip hidden fields - return; - } - if ( parent.hasClass( 'redux-field-init' ) ) { - parent.removeClass( 'redux-field-init' ); - } else { - return; - } - // On label click, change the input and class - el.find( '.redux-image-select label img, .redux-image-select label .tiles' ).click( - function( e ) { - var id = $( this ).closest( 'label' ).attr( 'for' ); - - $( this ).parents( "fieldset:first" ).find( '.redux-image-select-selected' ).removeClass( 'redux-image-select-selected' ).find( "input[type='radio']" ).attr( - "checked", false - ); - $( this ).closest( 'label' ).find( 'input[type="radio"]' ).prop( 'checked' ); - - if ( $( this ).closest( 'label' ).hasClass( 'redux-image-select-preset-' + id ) ) { // If they clicked on a preset, import! - e.preventDefault(); - - var presets = $( this ).closest( 'label' ).find( 'input' ); - var data = presets.data( 'presets' ); - var merge = presets.data( 'merge' ); - - if( merge !== undefined && merge !== null ) { - if( $.type( merge ) === 'string' ) { - merge = merge.split('|'); - } - - $.each(data, function( index, value ) { - if( ( merge === true || $.inArray( index, merge ) != -1 ) && $.type( redux.options[index] ) === 'object' ) { - data[index] = $.extend(redux.options[index], data[index]); - } - }); - } - - if ( presets !== undefined && presets !== null ) { - var answer = confirm( redux.args.preset_confirm ); - - if ( answer ) { - el.find( 'label[for="' + id + '"]' ).addClass( 'redux-image-select-selected' ).find( "input[type='radio']" ).attr( - "checked", true - ); - window.onbeforeunload = null; - if ( $( '#import-code-value' ).length === 0 ) { - $( this ).append( '' ); - } else { - $( '#import-code-value' ).val( JSON.stringify( data ) ); - } - if ( $( '#publishing-action #publish' ).length !== 0 ) { - $( '#publish' ).click(); - } else { - $( '#redux-import' ).click(); - } - } - } else { - } - - return false; - } else { - el.find( 'label[for="' + id + '"]' ).addClass( 'redux-image-select-selected' ).find( "input[type='radio']" ).attr( - "checked", true - ).trigger('change'); - - redux_change( $( this ).closest( 'label' ).find( 'input[type="radio"]' ) ); - } - } - ); - - // Used to display a full image preview of a tile/pattern - el.find( '.tiles' ).qtip( - { - content: { - text: function( event, api ) { - return ""; - }, - }, - style: 'qtip-tipsy', - position: { - my: 'top center', // Position my top left... - at: 'bottom center', // at the bottom right of... - } - } - ); - } - ); - - }; -})( jQuery ); \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/image_select/field_image_select.min.js b/library/admin/ReduxCore/inc/fields/image_select/field_image_select.min.js deleted file mode 100644 index c4e415ea..00000000 --- a/library/admin/ReduxCore/inc/fields/image_select/field_image_select.min.js +++ /dev/null @@ -1 +0,0 @@ -!function(a){"use strict";redux.field_objects=redux.field_objects||{},redux.field_objects.image_select=redux.field_objects.image_select||{},a(document).ready(function(){}),redux.field_objects.image_select.init=function(b){b||(b=a(document).find(".redux-group-tab:visible").find(".redux-container-image_select:visible")),a(b).each(function(){var b=a(this),c=b;b.hasClass("redux-field-container")||(c=b.parents(".redux-field-container:first")),c.is(":hidden")||c.hasClass("redux-field-init")&&(c.removeClass("redux-field-init"),b.find(".redux-image-select label img, .redux-image-select label .tiles").click(function(c){var d=a(this).closest("label").attr("for");if(a(this).parents("fieldset:first").find(".redux-image-select-selected").removeClass("redux-image-select-selected").find("input[type='radio']").attr("checked",!1),a(this).closest("label").find('input[type="radio"]').prop("checked"),a(this).closest("label").hasClass("redux-image-select-preset-"+d)){c.preventDefault();var e=a(this).closest("label").find("input"),f=e.data("presets"),g=e.data("merge");if(void 0!==g&&null!==g&&("string"===a.type(g)&&(g=g.split("|")),a.each(f,function(b,c){g!==!0&&-1==a.inArray(b,g)||"object"!==a.type(redux.options[b])||(f[b]=a.extend(redux.options[b],f[b]))})),void 0!==e&&null!==e){var h=confirm(redux.args.preset_confirm);h&&(b.find('label[for="'+d+'"]').addClass("redux-image-select-selected").find("input[type='radio']").attr("checked",!0),window.onbeforeunload=null,0===a("#import-code-value").length?a(this).append('"):a("#import-code-value").val(JSON.stringify(f)),0!==a("#publishing-action #publish").length?a("#publish").click():a("#redux-import").click())}return!1}b.find('label[for="'+d+'"]').addClass("redux-image-select-selected").find("input[type='radio']").attr("checked",!0).trigger("change"),redux_change(a(this).closest("label").find('input[type="radio"]'))}),b.find(".tiles").qtip({content:{text:function(b,c){return""}},style:"qtip-tipsy",position:{my:"top center",at:"bottom center"}}))})}}(jQuery); \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/image_select/field_image_select.php b/library/admin/ReduxCore/inc/fields/image_select/field_image_select.php deleted file mode 100644 index 534da02a..00000000 --- a/library/admin/ReduxCore/inc/fields/image_select/field_image_select.php +++ /dev/null @@ -1,274 +0,0 @@ -. - * - * @package ReduxFramework - * @subpackage Field_Images - * @author Daniel J Griffiths (Ghost1227) - * @author Dovy Paukstys - * @version 3.0.0 - */ - -// Exit if accessed directly -if ( ! defined( 'ABSPATH' ) ) { - exit; -} - -// Don't duplicate me! -if ( ! class_exists( 'ReduxFramework_image_select' ) ) { - - /** - * Main ReduxFramework_image_select class - * - * @since 1.0.0 - */ - class ReduxFramework_image_select { - - /** - * Field Constructor. - * Required - must call the parent constructor, then assign field and value to vars, and obviously call the render field function - * - * @since 1.0.0 - * @access public - * @return void - */ - function __construct( $field = array(), $value = '', $parent ) { - $this->parent = $parent; - $this->field = $field; - $this->value = $value; - } - - /** - * Field Render Function. - * Takes the vars and outputs the HTML for the field in the settings - * - * @since 1.0.0 - * @access public - * @return void - */ - public function render() { - - if ( ! empty( $this->field['options'] ) ) { - echo '
    '; - echo '
      '; - - $x = 1; - - foreach ( $this->field['options'] as $k => $v ) { - - if ( ! is_array( $v ) ) { - $v = array( 'img' => $v ); - } - - if ( ! isset( $v['title'] ) ) { - $v['title'] = ''; - } - - if ( ! isset( $v['alt'] ) ) { - $v['alt'] = $v['title']; - } - - if ( ! isset( $v['class'] ) ) { - $v['class'] = ''; - } - - $style = ''; - - if ( ! empty( $this->field['width'] ) ) { - $style .= 'width: ' . $this->field['width']; - - if ( is_numeric( $this->field['width'] ) ) { - $style .= 'px'; - } - - $style .= ';'; - } else { - $style .= " width: 100%; "; - } - - if ( ! empty( $this->field['height'] ) ) { - $style .= 'height: ' . $this->field['height']; - - if ( is_numeric( $this->field['height'] ) ) { - $style .= 'px'; - } - - $style .= ';'; - } - - $theValue = $k; - if ( ! empty( $this->field['tiles'] ) && $this->field['tiles'] == true ) { - $theValue = $v['img']; - } - - $selected = ( checked( $this->value, $theValue, false ) != '' ) ? ' redux-image-select-selected' : ''; - - $presets = ''; - $is_preset = false; - - $this->field['class'] .= ' noUpdate '; - if ( isset( $this->field['presets'] ) && $this->field['presets'] !== false ) { - $this->field['class'] = trim($this->field['class']); - if ( ! isset( $v['presets'] ) ) { - $v['presets'] = array(); - } - - if ( ! is_array( $v['presets'] ) ) { - $v['presets'] = json_decode( $v['presets'], true ); - } - - // Only highlight the preset if it's the same - if ( $selected ) { - if ( empty( $v['presets'] ) ) { - $selected = false; - } else { - foreach ( $v['presets'] as $pk => $pv ) { - if ( isset( $v['merge'] ) && $v['merge'] !== false ) { - if( ( $v['merge'] === true || in_array( $pk, $v['merge'] ) ) && is_array( $this->parent->options[ $pk ] ) ) { - $pv = array_merge( $this->parent->options[ $pk ], $pv ); - } - } - - if ( empty( $pv ) && isset( $this->parent->options[ $pk ] ) && ! empty( $this->parent->options[ $pk ] ) ) { - $selected = false; - } else if ( ! empty( $pv ) && ! isset( $this->parent->options[ $pk ] ) ) { - $selected = false; - } else if ( isset( $this->parent->options[ $pk ] ) && $this->parent->options[ $pk ] != $pv ) { - $selected = false; - } - - if ( ! $selected ) { // We're still not using the same preset. Let's unset that shall we? - $this->value = ""; - break; - } - } - } - } - - $v['presets']['redux-backup'] = 1; - - $presets = ' data-presets="' . htmlspecialchars( json_encode( $v['presets'] ), ENT_QUOTES, 'UTF-8' ) . '"'; - $is_preset = true; - - $this->field['class'] = trim( $this->field['class'] ) . ' redux-presets'; - } - - $is_preset_class = $is_preset ? '-preset-' : ' '; - - $merge = ''; - if ( isset( $v['merge'] ) && $v['merge'] !== false ) { - $merge = is_array( $v['merge'] ) ? implode( '|', $v['merge'] ) : 'true'; - $merge = ' data-merge="' . htmlspecialchars( $merge, ENT_QUOTES, 'UTF-8' ) . '"'; - } - - echo '
    • '; - echo ''; - echo '
    • '; - - $x ++; - } - - echo '
    '; - echo '
    '; - } - } - - /** - * Enqueue Function. - * If this field requires any scripts, or css define this function and register/enqueue the scripts/css - * - * @since 1.0.0 - * @access public - * @return void - */ - public function enqueue() { - - wp_enqueue_script( - 'redux-field-image-select-js', - ReduxFramework::$_url . 'inc/fields/image_select/field_image_select' . Redux_Functions::isMin() . '.js', - array( 'jquery', 'redux-js' ), - time(), - true - ); - - if ($this->parent->args['dev_mode']) { - wp_enqueue_style( - 'redux-field-image-select-css', - ReduxFramework::$_url . 'inc/fields/image_select/field_image_select.css', - array(), - time(), - 'all' - ); - } - } - - public function getCSS( $mode = '' ) { - $css = ''; - $value = $this->value; - - $output = ''; - if ( ! empty( $value ) && ! is_array($value) ) { - switch ( $mode ) { - case 'background-image': - $output = "background-image: url('" . $value . "');"; - break; - - default: - $output = $mode . ": " . $value . ";"; - } - } - - $css .= $output; - - return $css; - } - - public function output() { - $mode = ( isset( $this->field['mode'] ) && ! empty( $this->field['mode'] ) ? $this->field['mode'] : 'background-image' ); - - if ( ( ! isset( $this->field['output'] ) || ! is_array( $this->field['output'] ) ) && ( ! isset( $this->field['compiler'] ) ) ) { - return; - } - - $style = $this->getCSS( $mode ); - - if ( ! empty( $style ) ) { - - if ( ! empty( $this->field['output'] ) && is_array( $this->field['output'] ) ) { - $keys = implode( ",", $this->field['output'] ); - $style = $keys . "{" . $style . '}'; - $this->parent->outputCSS .= $style; - } - - if ( ! empty( $this->field['compiler'] ) && is_array( $this->field['compiler'] ) ) { - $keys = implode( ",", $this->field['compiler'] ); - $style = $keys . "{" . $style . '}'; - $this->parent->compilerCSS .= $style; - } - } - } - } -} \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/image_select/field_image_select.scss b/library/admin/ReduxCore/inc/fields/image_select/field_image_select.scss deleted file mode 100644 index 914ccd59..00000000 --- a/library/admin/ReduxCore/inc/fields/image_select/field_image_select.scss +++ /dev/null @@ -1,62 +0,0 @@ -.redux-container-image_select { - .redux-table-container { - display: table; - table-layout: fixed; - width: 100%; - } - - .redux-image-select { - margin: 0 !important; - - .tiles { - display: block; - background-color: #FFF; - background-repeat: repeat; - width: 40px; - height: 40px; - } - - img, - .tiles { - border-color: #d9d9d9; - } - - li:last-child { - margin-bottom: 0; - } - - input[type='radio'] { - display: none; - } - } - - .redux-image-select-presets img { - width: 100%; - } - - ul.redux-image-select li { - margin: 0 10px 3px 10px; - display: inline-block; - padding: 2px 2px; - padding-left: 0; - } - - .redux-image-select-selected { - background-color: #f9f9f9; - } - - .redux-image-select img, - .redux-image-select-selected img, - .redux-image-select .tiles, - .redux-image-select-selected .tiles { - border-width: 4px; - border-style: solid; - } - - .redux-image-select-selected, - .redux-image-select-selected { - .tiles { - border-color: #7a7a7a; - } - } -} \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/info/field_info.css b/library/admin/ReduxCore/inc/fields/info/field_info.css deleted file mode 100644 index 357214d3..00000000 --- a/library/admin/ReduxCore/inc/fields/info/field_info.css +++ /dev/null @@ -1 +0,0 @@ -.redux-info-field{min-height:20px;padding:8px 19px;margin:10px 0;border:1px solid;border-radius:4px;border:1px solid;position:relative}.redux-info-field h1,.redux-info-field h2,.redux-info-field h3,.redux-info-field h4,.redux-info-field h5,.redux-info-field h6{border-bottom:0 !important}.redux-info-field h3{color:#777}.redux-info-field .redux-info-icon{display:inline-block;margin-right:15px}.redux-info-field .redux-info-icon i{font-size:2em}.redux-info-field .redux-info-desc{display:inline-block;vertical-align:top}.redux-info-field.redux-normal{background-color:#eeeeee;border-color:#cccccc;color:#666666}.redux-info-field.redux-normal i{color:#c5c5c5}.redux-info-field.redux-warning{background-color:#fbeba4;border-color:#d7c281;color:#958234}.redux-info-field.redux-warning i{color:#dcca81}.redux-info-field.redux-success{background-color:#c4ee91;border-color:#71af5d;color:#4d7615}.redux-info-field.redux-success i{color:#a0ca6c}.redux-info-field.redux-critical{background-color:#fba1a3;border-color:#b84f5b;color:#981225}.redux-info-field.redux-critical i{color:#dd767d}.redux-info-field.redux-info{background-color:#d3e4f4;border-color:#a9b6c2;color:#5c80a1}.redux-info-field.redux-info i{color:#afc6da}.redux-notice-field{margin:15px 0 0;background-color:#fff;border:0;border-left:4px solid #f3f3f3;-webkit-box-shadow:0 1px 1px 0 rgba(0,0,0,0.1);box-shadow:0 1px 1px 0 rgba(0,0,0,0.1);padding:1px 12px}.redux-notice-field h1,.redux-notice-field h2,.redux-notice-field h3,.redux-notice-field h4,.redux-notice-field h5,.redux-notice-field h6{border-bottom:0 !important}.redux-notice-field p{margin:.5em 0;padding:2px}.redux-notice-field .redux-info-icon{display:inline-block;margin-right:15px}.redux-notice-field .redux-info-icon i{font-size:2em}.redux-notice-field .redux-info-desc{display:inline-block;vertical-align:top}.redux-notice-field.redux-info{border-left:4px solid #0099d5}.redux-notice-field.redux-success{border-left:4px solid #7ad03a}.redux-notice-field.redux-warning{border-left:4px solid #fbeba4}.redux-notice-field.redux-critical{border-left:4px solid #dd3d36}.redux-main .redux-field-container.redux-container-info{padding:0}.wp-customizer .hasIcon.redux-notice-field .redux-info-desc,.wp-customizer .hasIcon.redux-info-field .redux-info-desc{display:block;margin-left:43px}.wp-customizer .hasIcon.redux-notice-field .redux-info-icon,.wp-customizer .hasIcon.redux-info-field .redux-info-icon{float:left}.wp-customizer .redux-main .customize-control.customize-control-redux-info{border-bottom:0} diff --git a/library/admin/ReduxCore/inc/fields/info/field_info.php b/library/admin/ReduxCore/inc/fields/info/field_info.php deleted file mode 100644 index aecab96a..00000000 --- a/library/admin/ReduxCore/inc/fields/info/field_info.php +++ /dev/null @@ -1,167 +0,0 @@ -. - * - * @package ReduxFramework - * @subpackage Field_Info - * @author Daniel J Griffiths (Ghost1227) - * @author Dovy Paukstys - * @version 3.0.0 - */ - -// Exit if accessed directly - if ( ! defined( 'ABSPATH' ) ) { - exit; - } - -// Don't duplicate me! - if ( ! class_exists( 'ReduxFramework_info' ) ) { - - /** - * Main ReduxFramework_info class - * - * @since 1.0.0 - */ - class ReduxFramework_info { - - /** - * Field Constructor. - * Required - must call the parent constructor, then assign field and value to vars, and obviously call the render field function - * - * @since 1.0.0 - * @access public - * @return void - */ - function __construct( $field = array(), $value = '', $parent ) { - $this->parent = $parent; - $this->field = $field; - $this->value = $value; - } - - /** - * Field Render Function. - * Takes the vars and outputs the HTML for the field in the settings - * - * @since 1.0.0 - * @access public - * @return void - */ - public function render() { - - $defaults = array( - 'title' => '', - 'desc' => '', - 'notice' => true, - 'style' => '', - 'color' => '', - ); - - $this->field = wp_parse_args( $this->field, $defaults ); - - $styles = array( - 'normal', - 'info', - 'warning', - 'success', - 'critical', - 'custom' - ); - - if (!in_array($this->field['style'], $styles)) { - $this->field['style'] = 'normal'; - } - if ($this->field['style'] == "custom") { - if (!empty($this->field['color']) ) { - $this->field['color'] = "border-color:".$this->field['color'].';'; - } else { - $this->field['style'] = 'normal'; - $this->field['color'] = ""; - } - } else { - $this->field['color'] = ""; - } - - if ( empty( $this->field['desc'] ) && ! empty( $this->field['default'] ) ) { - $this->field['desc'] = $this->field['default']; - unset( $this->field['default'] ); - } - - if ( empty( $this->field['desc'] ) && ! empty( $this->field['subtitle'] ) ) { - $this->field['desc'] = $this->field['subtitle']; - unset( $this->field['subtitle'] ); - } - - if ( empty( $this->field['desc'] ) ) { - $this->field['desc'] = ""; - } - - if ( empty( $this->field['raw_html'] ) ) { - if ( $this->field['notice'] == true ) { - $this->field['class'] .= ' redux-notice-field'; - } else { - $this->field['class'] .= ' redux-info-field'; - } - - - - $this->field['style'] = 'redux-' . $this->field['style'] . ' '; - } - - $indent = ( isset( $this->field['sectionIndent'] ) && $this->field['sectionIndent'] ) ? ' form-table-section-indented' : ''; - - echo '
    field['style'] . ' ' . $this->field['class'] . ' redux-field-' . $this->field['type'] . $indent . '"'.( !empty($this->field['color']) ? ' style="'.$this->field['color'].'"' : '' ).'>'; - - if ( ! empty( $this->field['raw_html'] ) && $this->field['raw_html'] ) { - echo $this->field['desc']; - } else { - if ( isset( $this->field['title'] ) && ! empty( $this->field['title'] ) ) { - $this->field['title'] = '' . $this->field['title'] . '
    '; - } - - if ( isset( $this->field['icon'] ) && ! empty( $this->field['icon'] ) && $this->field['icon'] !== true ) { - echo '

    '; - } - - if ( isset( $this->field['raw'] ) && ! empty( $this->field['raw'] ) ) { - echo $this->field['raw']; - } - - if ( ! empty( $this->field['title'] ) || ! empty( $this->field['desc'] ) ) { - echo '

    ' . $this->field['title'] . $this->field['desc'] . '

    '; - } - } - - echo '
    '; - } - - /** - * Enqueue Function. - * If this field requires any scripts, or css define this function and register/enqueue the scripts/css - * - * @since 1.0.0 - * @access public - * @return void - */ - public function enqueue() { - if ($this->parent->args['dev_mode']) { - wp_enqueue_style( - 'redux-field-info-css', - ReduxFramework::$_url . 'inc/fields/info/field_info.css', - array(), - time(), - 'all' - ); - } - } - } - } \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/info/field_info.scss b/library/admin/ReduxCore/inc/fields/info/field_info.scss deleted file mode 100644 index 644801e2..00000000 --- a/library/admin/ReduxCore/inc/fields/info/field_info.scss +++ /dev/null @@ -1,159 +0,0 @@ -.redux-info-field { - min-height: 20px; - padding: 8px 19px; - margin: 10px 0; - border: 1px solid; - border-radius: 4px; - border: 1px solid; - position: relative; - - h1, - h2, - h3, - h4, - h5, - h6 { - border-bottom: 0 !important; - } - - h3 { - color: #777; - } - - .redux-info-icon { - display: inline-block; - margin-right: 15px; - - i { - font-size: 2em; - } - } - - .redux-info-desc { - display: inline-block; - vertical-align: top; - } - - &.redux-normal { - background-color: #eeeeee; - border-color: #cccccc; - color: #666666; - - i { - color: #c5c5c5; - } - } - - &.redux-warning { - background-color: #fbeba4; - border-color: #d7c281; - color: #958234; - - i { - color: #dcca81; - } - } - - &.redux-success { - background-color: #c4ee91; - border-color: #71af5d; - color: #4d7615; - - i { - color: #a0ca6c; - } - } - - &.redux-critical { - background-color: #fba1a3; - border-color: #b84f5b; - color: #981225; - - i { - color: #dd767d; - } - } - - &.redux-info { - background-color: #d3e4f4; - border-color: #a9b6c2; - color: #5c80a1; - - i { - color: #afc6da; - } - } -} - -.redux-notice-field { - margin: 15px 0 0; - background-color: #fff; - border: 0; - border-left: 4px solid #f3f3f3; - -webkit-box-shadow: 0 1px 1px 0 rgba(0, 0, 0, .1); - box-shadow: 0 1px 1px 0 rgba(0, 0, 0, .1); - padding: 1px 12px; - - h1, - h2, - h3, - h4, - h5, - h6 { - border-bottom: 0 !important; - } - - p { - margin: .5em 0; - padding: 2px; - } - - .redux-info-icon { - display: inline-block; - margin-right: 15px; - - i { - font-size: 2em; - } - } - - .redux-info-desc { - display: inline-block; - vertical-align: top; - } - - &.redux-info { - border-left: 4px solid #0099d5; - } - - &.redux-success { - border-left: 4px solid #7ad03a; - } - - &.redux-warning { - border-left: 4px solid #fbeba4; - } - - &.redux-critical { - border-left: 4px solid #dd3d36; - } -} - -.redux-main .redux-field-container.redux-container-info { - padding: 0; -} - -.wp-customizer { - .hasIcon.redux-notice-field, .hasIcon.redux-info-field { - .redux-info-desc { - display: block; - margin-left: 43px; - } - .redux-info-icon { - float: left; - } - } - .redux-main .customize-control.customize-control-redux-info { - border-bottom: 0; - } -} \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/link_color/field_link_color.css b/library/admin/ReduxCore/inc/fields/link_color/field_link_color.css deleted file mode 100644 index e19ead0b..00000000 --- a/library/admin/ReduxCore/inc/fields/link_color/field_link_color.css +++ /dev/null @@ -1 +0,0 @@ -.redux-container-link_color .linkColor{display:inline-block;padding-right:10px;padding-bottom:7px} diff --git a/library/admin/ReduxCore/inc/fields/link_color/field_link_color.js b/library/admin/ReduxCore/inc/fields/link_color/field_link_color.js deleted file mode 100644 index 48d5e2bf..00000000 --- a/library/admin/ReduxCore/inc/fields/link_color/field_link_color.js +++ /dev/null @@ -1,111 +0,0 @@ -/* - Field Link Color - */ - -/*global jQuery, document, redux_change, redux*/ - -(function( $ ) { - 'use strict'; - - redux.field_objects = redux.field_objects || {}; - redux.field_objects.link_color = redux.field_objects.link_color || {}; - - $( document ).ready( - function() { - - } - ); - - redux.field_objects.link_color.init = function( selector ) { - - if ( !selector ) { - selector = $( document ).find( '.redux-container-link_color:visible' ); - } - - $( selector ).each( - function() { - var el = $( this ); - var parent = el; - - if ( !el.hasClass( 'redux-field-container' ) ) { - parent = el.parents( '.redux-field-container:first' ); - } - if ( parent.is( ":hidden" ) ) { // Skip hidden fields - return; - } - if ( parent.hasClass( 'redux-field-init' ) ) { - parent.removeClass( 'redux-field-init' ); - } else { - return; - } - - el.find( '.redux-color-init' ).wpColorPicker( - { - change: function( e, ui ) { - $( this ).val( ui.color.toString() ); - redux_change( $( this ) ); - el.find( '#' + e.target.getAttribute( 'data-id' ) + '-transparency' ).removeAttr( 'checked' ); - }, - clear: function( e, ui ) { - $( this ).val( ui.color.toString() ); - redux_change( $( this ).parent().find( '.redux-color-init' ) ); - } - } - ); - - el.find( '.redux-color' ).on( - 'keyup', function() { - var value = $( this ).val(); - var color = colorValidate( this ); - var id = '#' + $( this ).attr( 'id' ); - - if ( value === "transparent" ) { - $( this ).parent().parent().find( '.wp-color-result' ).css( - 'background-color', 'transparent' - ); - - el.find( id + '-transparency' ).attr( 'checked', 'checked' ); - } else { - el.find( id + '-transparency' ).removeAttr( 'checked' ); - - if ( color && color !== $( this ).val() ) { - $( this ).val( color ); - } - } - } - ); - - // Replace and validate field on blur - el.find( '.redux-color' ).on( - 'blur', function() { - var value = $( this ).val(); - var id = '#' + $( this ).attr( 'id' ); - - if ( value === "transparent" ) { - $( this ).parent().parent().find( '.wp-color-result' ).css( - 'background-color', 'transparent' - ); - - el.find( id + '-transparency' ).attr( 'checked', 'checked' ); - } else { - if ( colorValidate( this ) === value ) { - if ( value.indexOf( "#" ) !== 0 ) { - $( this ).val( $( this ).data( 'oldcolor' ) ); - } - } - - el.find( id + '-transparency' ).removeAttr( 'checked' ); - } - } - ); - - // Store the old valid color on keydown - el.find( '.redux-color' ).on( - 'keydown', function() { - $( this ).data( 'oldkeypress', $( this ).val() ); - } - ); - } - ); - }; -})( jQuery ); diff --git a/library/admin/ReduxCore/inc/fields/link_color/field_link_color.min.js b/library/admin/ReduxCore/inc/fields/link_color/field_link_color.min.js deleted file mode 100644 index 354f8ea6..00000000 --- a/library/admin/ReduxCore/inc/fields/link_color/field_link_color.min.js +++ /dev/null @@ -1 +0,0 @@ -!function(a){"use strict";redux.field_objects=redux.field_objects||{},redux.field_objects.link_color=redux.field_objects.link_color||{},a(document).ready(function(){}),redux.field_objects.link_color.init=function(b){b||(b=a(document).find(".redux-container-link_color:visible")),a(b).each(function(){var b=a(this),c=b;b.hasClass("redux-field-container")||(c=b.parents(".redux-field-container:first")),c.is(":hidden")||c.hasClass("redux-field-init")&&(c.removeClass("redux-field-init"),b.find(".redux-color-init").wpColorPicker({change:function(c,d){a(this).val(d.color.toString()),redux_change(a(this)),b.find("#"+c.target.getAttribute("data-id")+"-transparency").removeAttr("checked")},clear:function(b,c){a(this).val(c.color.toString()),redux_change(a(this).parent().find(".redux-color-init"))}}),b.find(".redux-color").on("keyup",function(){var c=a(this).val(),d=colorValidate(this),e="#"+a(this).attr("id");"transparent"===c?(a(this).parent().parent().find(".wp-color-result").css("background-color","transparent"),b.find(e+"-transparency").attr("checked","checked")):(b.find(e+"-transparency").removeAttr("checked"),d&&d!==a(this).val()&&a(this).val(d))}),b.find(".redux-color").on("blur",function(){var c=a(this).val(),d="#"+a(this).attr("id");"transparent"===c?(a(this).parent().parent().find(".wp-color-result").css("background-color","transparent"),b.find(d+"-transparency").attr("checked","checked")):(colorValidate(this)===c&&0!==c.indexOf("#")&&a(this).val(a(this).data("oldcolor")),b.find(d+"-transparency").removeAttr("checked"))}),b.find(".redux-color").on("keydown",function(){a(this).data("oldkeypress",a(this).val())}))})}}(jQuery); \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/link_color/field_link_color.php b/library/admin/ReduxCore/inc/fields/link_color/field_link_color.php deleted file mode 100644 index 7a3d314e..00000000 --- a/library/admin/ReduxCore/inc/fields/link_color/field_link_color.php +++ /dev/null @@ -1,207 +0,0 @@ -. - * - * @package ReduxFramework - * @subpackage Field_Color_Gradient - * @author Luciano "WebCaos" Ubertini - * @author Daniel J Griffiths (Ghost1227) - * @author Dovy Paukstys - * @version 3.0.0 - */ - -// Exit if accessed directly -if ( ! defined( 'ABSPATH' ) ) { - exit; -} - -// Don't duplicate me! -if ( ! class_exists( 'ReduxFramework_link_color' ) ) { - - /** - * Main ReduxFramework_link_color class - * - * @since 1.0.0 - */ - class ReduxFramework_link_color { - - /** - * Field Constructor. - * Required - must call the parent constructor, then assign field and value to vars, and obviously call the render field function - * - * @since 1.0.0 - * @access public - * @return void - */ - function __construct( $field = array(), $value = '', $parent ) { - $this->parent = $parent; - $this->field = $field; - $this->value = $value; - - $defaults = array( - 'regular' => true, - 'hover' => true, - 'visited' => false, - 'active' => true - ); - $this->field = wp_parse_args( $this->field, $defaults ); - - $defaults = array( - 'regular' => '', - 'hover' => '', - 'visited' => '', - 'active' => '' - ); - - $this->value = wp_parse_args( $this->value, $defaults ); - - // In case user passes no default values. - if ( isset( $this->field['default'] ) ) { - $this->field['default'] = wp_parse_args( $this->field['default'], $defaults ); - } else { - $this->field['default'] = $defaults; - } - } - - /** - * Field Render Function. - * Takes the vars and outputs the HTML for the field in the settings - * - * @since 1.0.0 - * @access public - * @return void - */ - public function render() { - - if ( $this->field['regular'] === true && $this->field['default']['regular'] !== false ) { - echo '' . __( 'Regular', 'redux-framework' ) . ' '; - } - - if ( $this->field['hover'] === true && $this->field['default']['hover'] !== false ) { - echo '' . __( 'Hover', 'redux-framework' ) . ' '; - } - - if ( $this->field['visited'] === true && $this->field['default']['visited'] !== false ) { - echo '' . __( 'Visited', 'redux-framework' ) . ' '; - } - - if ( $this->field['active'] === true && $this->field['default']['active'] !== false ) { - echo '' . __( 'Active', 'redux-framework' ) . ' '; - } - } - - /** - * Enqueue Function. - * If this field requires any scripts, or css define this function and register/enqueue the scripts/css - * - * @since 1.0.0 - * @access public - * @return void - */ - public function enqueue() { - wp_enqueue_style( 'wp-color-picker' ); - - wp_enqueue_script( - 'redux-field-link-color-js', - ReduxFramework::$_url . 'inc/fields/link_color/field_link_color' . Redux_Functions::isMin() . '.js', - array( 'jquery', 'wp-color-picker', 'redux-js' ), - time(), - true - ); - - if ($this->parent->args['dev_mode']) { - wp_enqueue_style( 'redux-color-picker-css' ); - - wp_enqueue_style( - 'redux-field-link_color-js', - ReduxFramework::$_url . 'inc/fields/link_color/field_link_color.css', - array(), - time(), - 'all' - ); - } - } - - public function output() { - - $style = array(); - - if ( ! empty( $this->value['regular'] ) && $this->field['regular'] === true && $this->field['default']['regular'] !== false ) { - $style[] = 'color:' . $this->value['regular'] . ';'; - } - - if ( ! empty( $this->value['visited'] ) && $this->field['visited'] === true && $this->field['default']['visited'] !== false ) { - $style['visited'] = 'color:' . $this->value['visited'] . ';'; - } - - if ( ! empty( $this->value['hover'] ) && $this->field['hover'] === true && $this->field['default']['hover'] !== false ) { - $style['hover'] = 'color:' . $this->value['hover'] . ';'; - } - - if ( ! empty( $this->value['active'] ) && $this->field['active'] === true && $this->field['default']['active'] !== false ) { - $style['active'] = 'color:' . $this->value['active'] . ';'; - } - - if ( ! empty( $style ) ) { - if ( ! empty( $this->field['output'] ) && is_array( $this->field['output'] ) ) { - $styleString = ""; - - foreach ( $style as $key => $value ) { - if ( is_numeric( $key ) ) { - $styleString .= implode( ",", $this->field['output'] ) . "{" . $value . '}'; - } else { - if ( count( $this->field['output'] ) == 1 ) { - $styleString .= $this->field['output'][0] . ":" . $key . "{" . $value . '}'; - } else { - $blah = ''; - foreach($this->field['output'] as $k => $sel) { - $blah .= $sel . ':' . $key . ','; - } - - $blah = substr($blah, 0, strlen($blah) - 1); - $styleString .= $blah . '{' . $value . '}'; - - } - } - } - - $this->parent->outputCSS .= $styleString; - } - - if ( ! empty( $this->field['compiler'] ) && is_array( $this->field['compiler'] ) ) { - $styleString = ""; - - foreach ( $style as $key => $value ) { - if ( is_numeric( $key ) ) { - $styleString .= implode( ",", $this->field['compiler'] ) . "{" . $value . '}'; - - } else { - if ( count( $this->field['compiler'] ) == 1 ) { - $styleString .= $this->field['compiler'][0] . ":" . $key . "{" . $value . '}'; - } else { - $blah = ''; - foreach($this->field['compiler'] as $k => $sel) { - $blah .= $sel . ':' . $key . ','; - } - - $blah = substr($blah, 0, strlen($blah) - 1); - $styleString .= $blah . '{' . $value . '}'; - } - } - } - $this->parent->compilerCSS .= $styleString; - } - } - } - } -} \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/link_color/field_link_color.scss b/library/admin/ReduxCore/inc/fields/link_color/field_link_color.scss deleted file mode 100644 index e3b66dd1..00000000 --- a/library/admin/ReduxCore/inc/fields/link_color/field_link_color.scss +++ /dev/null @@ -1,7 +0,0 @@ -.redux-container-link_color { - .linkColor { - display: inline-block; - padding-right: 10px; - padding-bottom: 7px; - } -} \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/media/field_media.css b/library/admin/ReduxCore/inc/fields/media/field_media.css deleted file mode 100644 index 737309c1..00000000 --- a/library/admin/ReduxCore/inc/fields/media/field_media.css +++ /dev/null @@ -1 +0,0 @@ -.redux-main .button.remove-image,.redux-main .removeCSS{margin-left:10px;color:#ef521d}.redux-main .button.remove-image:hover,.redux-main .removeCSS:hover{color:red}.redux-main .upload_button_div{margin-bottom:5px}.redux-main .upload-error{float:left;color:#666;font-size:10px;font-weight:bold;text-decoration:none;text-shadow:1px 1px 0 #FFFFFF;margin:0 10px 0 0;padding:3px 10px;background:#FFDFEC;-webkit-border-radius:4px;-moz-border-radius:4px;border-radius:4px}.redux-main .reset-button{font-family:Arial, Verdana, sans-serif;float:left;margin:0;color:#ef521d;border-color:#bbb}.redux-main .redux-option-image{max-height:340px;max-width:340px;padding:5px;margin-bottom:0;margin-top:10px;margin-right:15px;border:1px solid #e3e3e3;background:#f7f7f7;-moz-border-radius:3px;-khtml-border-radius:3px;-webkit-border-radius:3px;border-radius:3px}.redux-main .redux-main .upload{width:80% !important}.redux-main .button{margin-top:2px} diff --git a/library/admin/ReduxCore/inc/fields/media/field_media.less b/library/admin/ReduxCore/inc/fields/media/field_media.less deleted file mode 100644 index f78c19bb..00000000 --- a/library/admin/ReduxCore/inc/fields/media/field_media.less +++ /dev/null @@ -1,53 +0,0 @@ -.redux-main { - .button.remove-image, .removeCSS { - margin-left: 10px; - color: #ef521d; - } - .button.remove-image:hover, .removeCSS:hover { - color: red; - } - .upload_button_div { - margin-bottom: 5px; - } - .upload-error { - float: left; - color: #666; - font-size: 10px; - font-weight: bold; - text-decoration: none; - text-shadow: 1px 1px 0 #FFFFFF; - margin: 0 10px 0 0; - padding: 3px 10px; - background: #FFDFEC; - -webkit-border-radius: 4px; - -moz-border-radius: 4px; - border-radius: 4px; - } - .reset-button { - font-family: Arial, Verdana, sans-serif; - float: left; - margin: 0; - color: #ef521d; - border-color: #bbb; - } - .redux-option-image { - max-height: 340px; - max-width: 340px; - padding: 5px; - margin-bottom: 0; - margin-top: 10px; - margin-right: 15px; - border: 1px solid #e3e3e3; - background: #f7f7f7; - -moz-border-radius: 3px; - -khtml-border-radius: 3px; - -webkit-border-radius: 3px; - border-radius: 3px; - } - .redux-main .upload { - width: 80% !important; - } - .button { - margin-top: 2px; - } -} diff --git a/library/admin/ReduxCore/inc/fields/media/field_media.php b/library/admin/ReduxCore/inc/fields/media/field_media.php deleted file mode 100644 index bd6ec6a3..00000000 --- a/library/admin/ReduxCore/inc/fields/media/field_media.php +++ /dev/null @@ -1,238 +0,0 @@ -. - * - * @package ReduxFramework - * @subpackage Field_Media - * @author Daniel J Griffiths (Ghost1227) - * @author Dovy Paukstys - * @author Kevin Provance (kprovance) - * @version 3.0.0 - */ - -// Exit if accessed directly -if ( ! defined( 'ABSPATH' ) ) { - exit; -} - -// Don't duplicate me! -if ( ! class_exists( 'ReduxFramework_media' ) ) { - - /** - * Main ReduxFramework_media class - * - * @since 1.0.0 - */ - class ReduxFramework_media { - - /** - * Field Constructor. - * Required - must call the parent constructor, then assign field and value to vars, and obviously call the render field function - * - * @since 1.0.0 - * @access public - * @return void - */ - function __construct( $field = array(), $value = '', $parent ) { - $this->parent = $parent; - $this->field = $field; - $this->value = $value; - } - - /** - * Field Render Function. - * Takes the vars and outputs the HTML for the field in the settings - * - * @since 1.0.0 - * @access public - * @return void - */ - public function render() { - - // No errors please - $defaults = array( - 'id' => '', - 'url' => '', - 'width' => '', - 'height' => '', - 'thumbnail' => '', - ); - - $this->value = wp_parse_args( $this->value, $defaults ); - - if (isset($this->field['mode']) && $this->field['mode'] == false) { - $this->field['mode'] = 0; - } - - if ( ! isset( $this->field['mode'] ) ) { - $this->field['mode'] = "image"; - } - - if (!isset($this->field['library_filter'])) { - $libFilter = ''; - } else { - if (!is_array($this->field['library_filter'])) { - $this->field['library_filter'] = array($this->field['library_filter']); - } - - $mimeTypes = get_allowed_mime_types(); - - $libArray = $this->field['library_filter']; - - $jsonArr = array(); - - // Enum mime types - foreach ($mimeTypes as $ext => $type) { - if (strpos($ext,'|')) { - $expArr = explode('|', $ext); - - foreach($expArr as $ext){ - if (in_array($ext, $libArray )) { - $jsonArr[$ext] = $type; - } - } - } elseif (in_array($ext, $libArray )) { - $jsonArr[$ext] = $type; - } - - } - - $libFilter = urlencode(json_encode($jsonArr)); - } - - if ( empty( $this->value ) && ! empty( $this->field['default'] ) ) { // If there are standard values and value is empty - if ( is_array( $this->field['default'] ) ) { - if ( ! empty( $this->field['default']['id'] ) ) { - $this->value['id'] = $this->field['default']['id']; - } - - if ( ! empty( $this->field['default']['url'] ) ) { - $this->value['url'] = $this->field['default']['url']; - } - } else { - if ( is_numeric( $this->field['default'] ) ) { // Check if it's an attachment ID - $this->value['id'] = $this->field['default']; - } else { // Must be a URL - $this->value['url'] = $this->field['default']; - } - } - } - - - if ( empty( $this->value['url'] ) && ! empty( $this->value['id'] ) ) { - $img = wp_get_attachment_image_src( $this->value['id'], 'full' ); - $this->value['url'] = $img[0]; - $this->value['width'] = $img[1]; - $this->value['height'] = $img[2]; - } - - $hide = 'hide '; - - if ( ( isset( $this->field['preview'] ) && $this->field['preview'] === false ) ) { - $this->field['class'] .= " noPreview"; - } - - if ( ( ! empty( $this->field['url'] ) && $this->field['url'] === true ) || isset( $this->field['preview'] ) && $this->field['preview'] === false ) { - $hide = ''; - } - - $placeholder = isset( $this->field['placeholder'] ) ? $this->field['placeholder'] : __( 'No media selected', 'redux-framework' ); - - $readOnly = ' readonly="readonly"'; - if ( isset( $this->field['readonly'] ) && $this->field['readonly'] === false ) { - $readOnly = ''; - } - - echo ''; - echo ''; - echo ''; - echo ''; - echo ''; - echo ''; - echo ''; - - //Preview - $hide = ''; - - if ( ( isset( $this->field['preview'] ) && $this->field['preview'] === false ) || empty( $this->value['url'] ) ) { - $hide = 'hide '; - } - - if ( empty( $this->value['thumbnail'] ) && ! empty( $this->value['url'] ) ) { // Just in case - if ( ! empty( $this->value['id'] ) ) { - $image = wp_get_attachment_image_src( $this->value['id'], array( - 150, - 150 - ) ); - - if (empty($image[0]) || $image[0] == '') { - $this->value['thumbnail'] = $this->value['url']; - } else { - $this->value['thumbnail'] = $image[0]; - } - } else { - $this->value['thumbnail'] = $this->value['url']; - } - } - - echo '
    '; - echo ''; - echo ''; - echo ''; - echo '
    '; - - //Upload controls DIV - echo '
    '; - - //If the user has WP3.5+ show upload/remove button - echo '' . __( 'Upload', 'redux-framework' ) . ''; - - $hide = ''; - if ( empty( $this->value['url'] ) || $this->value['url'] == '' ) { - $hide = ' hide'; - } - - echo '' . __( 'Remove', 'redux-framework' ) . ''; - - echo '
    '; - } - - /** - * Enqueue Function. - * If this field requires any scripts, or css define this function and register/enqueue the scripts/css - * - * @since 1.0.0 - * @access public - * @return void - */ - public function enqueue() { - if ( function_exists( 'wp_enqueue_media' ) ) { - wp_enqueue_media(); - } else { - wp_enqueue_script( 'media-upload' ); - } - - wp_enqueue_script( - 'redux-field-media-js', - ReduxFramework::$_url . 'assets/js/media/media' . Redux_Functions::isMin() . '.js', - array( 'jquery', 'redux-js' ), - time(), - true - ); - - if ($this->parent->args['dev_mode']) { - wp_enqueue_style('redux-field-media-css'); - } - } - } -} \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/media/field_media.scss b/library/admin/ReduxCore/inc/fields/media/field_media.scss deleted file mode 100644 index 86086aed..00000000 --- a/library/admin/ReduxCore/inc/fields/media/field_media.scss +++ /dev/null @@ -1,61 +0,0 @@ -.redux-main { - .button.remove-image, - .removeCSS { - margin-left: 10px; - color: #ef521d; - - &:hover { - color: red; - } - } - - .upload_button_div { - margin-bottom: 5px; - } - - .upload-error { - float: left; - color: #666; - font-size: 10px; - font-weight: bold; - text-decoration: none; - text-shadow: 1px 1px 0 #FFFFFF; - margin: 0 10px 0 0; - padding: 3px 10px; - background: #FFDFEC; - -webkit-border-radius: 4px; - -moz-border-radius: 4px; - border-radius: 4px; - } - - .reset-button { - font-family: Arial, Verdana, sans-serif; - float: left; - margin: 0; - color: #ef521d; - border-color: #bbb; - } - - .redux-option-image { - max-height: 340px; - max-width: 340px; - padding: 5px; - margin-bottom: 0; - margin-top: 10px; - margin-right: 15px; - border: 1px solid #e3e3e3; - background: #f7f7f7; - -moz-border-radius: 3px; - -khtml-border-radius: 3px; - -webkit-border-radius: 3px; - border-radius: 3px; - } - - .redux-main .upload { - width: 80% !important; - } - - .button { - margin-top: 2px; - } -} \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/multi_text/field_multi_text.css b/library/admin/ReduxCore/inc/fields/multi_text/field_multi_text.css deleted file mode 100644 index 5ec0cd6f..00000000 --- a/library/admin/ReduxCore/inc/fields/multi_text/field_multi_text.css +++ /dev/null @@ -1 +0,0 @@ -.redux-container-multi_text ul.redux-multi-text{margin:0;padding:0}.redux-container-multi_text .redux-multi-text-add{clear:both;margin:5px 0}@media screen and (max-width: 782px){.redux-container-multi_text input{clear:both}.redux-container-multi_text .redux-multi-text-remove{margin:0;float:right}}.redux-container .redux-multi-text-remove,.redux-container a.redux-multi-text-remove,.deletion{color:#F00;padding:2px 4px;margin-left:5px;background:orange}.redux-container .redux-multi-text-remove:hover,.redux-container a.redux-multi-text-remove:hover,.deletion:hover{background:red;color:#fff;text-decoration:none}.wp-customizer .redux-container-multi_text .button{float:right}.wp-customizer .redux-container-multi_text .redux-multi-text-remove{float:right;margin-bottom:5px}.wp-customizer .redux-container-multi_text ul.redux-multi-text input{width:100% !important} diff --git a/library/admin/ReduxCore/inc/fields/multi_text/field_multi_text.js b/library/admin/ReduxCore/inc/fields/multi_text/field_multi_text.js deleted file mode 100644 index c8b3df2b..00000000 --- a/library/admin/ReduxCore/inc/fields/multi_text/field_multi_text.js +++ /dev/null @@ -1,65 +0,0 @@ -/*global redux_change, redux*/ - -(function( $ ) { - "use strict"; - - redux.field_objects = redux.field_objects || {}; - redux.field_objects.multi_text = redux.field_objects.multi_text || {}; - - $( document ).ready( - function() { - //redux.field_objects.multi_text.init(); - } - ); - - redux.field_objects.multi_text.init = function( selector ) { - - if ( !selector ) { - selector = $( document ).find( '.redux-container-multi_text:visible' ); - } - - $( selector ).each( - function() { - var el = $( this ); - var parent = el; - if ( !el.hasClass( 'redux-field-container' ) ) { - parent = el.parents( '.redux-field-container:first' ); - } - if ( parent.is( ":hidden" ) ) { // Skip hidden fields - return; - } - if ( parent.hasClass( 'redux-field-init' ) ) { - parent.removeClass( 'redux-field-init' ); - } else { - return; - } - el.find( '.redux-multi-text-remove' ).live( - 'click', function() { - redux_change( $( this ) ); - $( this ).prev( 'input[type="text"]' ).val( '' ); - $( this ).parent().slideUp( - 'medium', function() { - $( this ).remove(); - } - ); - } - ); - - el.find( '.redux-multi-text-add' ).click( - function() { - var number = parseInt( $( this ).attr( 'data-add_number' ) ); - var id = $( this ).attr( 'data-id' ); - var name = $( this ).attr( 'data-name' ); - for ( var i = 0; i < number; i++ ) { - var new_input = $( '#' + id + ' li:last-child' ).clone(); - el.find( '#' + id ).append( new_input ); - el.find( '#' + id + ' li:last-child' ).removeAttr( 'style' ); - el.find( '#' + id + ' li:last-child input[type="text"]' ).val( '' ); - el.find( '#' + id + ' li:last-child input[type="text"]' ).attr( 'name', name ); - } - } - ); - } - ); - }; -})( jQuery ); \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/multi_text/field_multi_text.min.js b/library/admin/ReduxCore/inc/fields/multi_text/field_multi_text.min.js deleted file mode 100644 index 06c2cd14..00000000 --- a/library/admin/ReduxCore/inc/fields/multi_text/field_multi_text.min.js +++ /dev/null @@ -1 +0,0 @@ -!function(a){"use strict";redux.field_objects=redux.field_objects||{},redux.field_objects.multi_text=redux.field_objects.multi_text||{},a(document).ready(function(){}),redux.field_objects.multi_text.init=function(b){b||(b=a(document).find(".redux-container-multi_text:visible")),a(b).each(function(){var b=a(this),c=b;b.hasClass("redux-field-container")||(c=b.parents(".redux-field-container:first")),c.is(":hidden")||c.hasClass("redux-field-init")&&(c.removeClass("redux-field-init"),b.find(".redux-multi-text-remove").live("click",function(){redux_change(a(this)),a(this).prev('input[type="text"]').val(""),a(this).parent().slideUp("medium",function(){a(this).remove()})}),b.find(".redux-multi-text-add").click(function(){for(var c=parseInt(a(this).attr("data-add_number")),d=a(this).attr("data-id"),e=a(this).attr("data-name"),f=0;c>f;f++){var g=a("#"+d+" li:last-child").clone();b.find("#"+d).append(g),b.find("#"+d+" li:last-child").removeAttr("style"),b.find("#"+d+' li:last-child input[type="text"]').val(""),b.find("#"+d+' li:last-child input[type="text"]').attr("name",e)}}))})}}(jQuery); \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/multi_text/field_multi_text.php b/library/admin/ReduxCore/inc/fields/multi_text/field_multi_text.php deleted file mode 100644 index d0621725..00000000 --- a/library/admin/ReduxCore/inc/fields/multi_text/field_multi_text.php +++ /dev/null @@ -1,113 +0,0 @@ -. - * - * @package ReduxFramework - * @subpackage Field_Multi_Text - * @author Daniel J Griffiths (Ghost1227) - * @author Dovy Paukstys - * @version 3.0.0 - */ - -// Exit if accessed directly -if ( ! defined( 'ABSPATH' ) ) { - exit; -} - -// Don't duplicate me! -if ( ! class_exists( 'ReduxFramework_multi_text' ) ) { - - /** - * Main ReduxFramework_multi_text class - * - * @since 1.0.0 - */ - class ReduxFramework_multi_text { - - /** - * Field Constructor. - * Required - must call the parent constructor, then assign field and value to vars, and obviously call the render field function - * - * @since 1.0.0 - * @access public - * @return void - */ - function __construct( $field = array(), $value = '', $parent ) { - $this->parent = $parent; - $this->field = $field; - $this->value = $value; - } - - /** - * Field Render Function. - * Takes the vars and outputs the HTML for the field in the settings - * - * @since 1.0.0 - * @access public - * @return void - */ - public function render() { - - $this->add_text = ( isset( $this->field['add_text'] ) ) ? $this->field['add_text'] : __( 'Add More', 'redux-framework' ); - $this->show_empty = ( isset( $this->field['show_empty'] ) ) ? $this->field['show_empty'] : true; - - echo ''; - echo ''; - $this->field['add_number'] = ( isset( $this->field['add_number'] ) && is_numeric( $this->field['add_number'] ) ) ? $this->field['add_number'] : 1; - echo '' . $this->add_text . '
    '; - } - - /** - * Enqueue Function. - * If this field requires any scripts, or css define this function and register/enqueue the scripts/css - * - * @since 1.0.0 - * @access public - * @return void - */ - public function enqueue() { - - wp_enqueue_script( - 'redux-field-multi-text-js', - ReduxFramework::$_url . 'inc/fields/multi_text/field_multi_text' . Redux_Functions::isMin() . '.js', - array( 'jquery', 'redux-js' ), - time(), - true - ); - - if ($this->parent->args['dev_mode']) { - wp_enqueue_style( - 'redux-field-multi-text-css', - ReduxFramework::$_url . 'inc/fields/multi_text/field_multi_text.css', - array(), - time(), - true - ); - } - } - } -} \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/multi_text/field_multi_text.scss b/library/admin/ReduxCore/inc/fields/multi_text/field_multi_text.scss deleted file mode 100644 index fcd47c48..00000000 --- a/library/admin/ReduxCore/inc/fields/multi_text/field_multi_text.scss +++ /dev/null @@ -1,52 +0,0 @@ -.redux-container-multi_text { - ul.redux-multi-text { - margin: 0; - padding: 0; - } - - .redux-multi-text-add { - clear: both; - margin: 5px 0; - } - -} - -@media screen and (max-width: 782px) { - .redux-container-multi_text { - input { - clear: both; - } - - .redux-multi-text-remove { - margin: 0; - float: right; - } - } -} - -.redux-container .redux-multi-text-remove, .redux-container a.redux-multi-text-remove, .deletion { - color: #F00; - padding: 2px 4px; - margin-left: 5px; - background: orange; - &:hover { - background: red; - color: #fff; - text-decoration: none; - } -} - -.wp-customizer { - .redux-container-multi_text { - .button { - float: right; - } - .redux-multi-text-remove { - float: right; - margin-bottom: 5px; - } - ul.redux-multi-text input { - width: 100% !important; - } - } -} diff --git a/library/admin/ReduxCore/inc/fields/palette/field_palette.css b/library/admin/ReduxCore/inc/fields/palette/field_palette.css deleted file mode 100644 index 17d81fbe..00000000 --- a/library/admin/ReduxCore/inc/fields/palette/field_palette.css +++ /dev/null @@ -1 +0,0 @@ -.redux-container-palette label{border:3px solid transparent;border-color:transparent !important;border-radius:0;width:100% !important;display:block}.redux-container-palette label.ui-button.ui-widget{width:95%;background:none;padding:0}.redux-container-palette label.ui-button.ui-widget .ui-button-text{display:flex}.redux-container-palette label.ui-button.ui-widget .ui-button-text span{padding:10px;flex-grow:1;font-size:0;line-height:10px;color:transparent;-webkit-transition:all 200ms ease-in-out;-moz-transition:all 200ms ease-in-out;-ms-transition:all 200ms ease-in-out;-o-transition:all 200ms ease-in-out;transition:all 200ms ease-in-out;text-shadow:0}.redux-container-palette label.ui-button.ui-widget .ui-button-text span:hover{flex-grow:3;font-weight:bold;min-width:60px;font-size:12px;line-height:10px;color:#333;text-shadow:0 0 8px #fff, 0 0 8px #fff}.redux-container-palette label.ui-state-active{border:3px solid #333 !important}.wp-customizer .redux-main .redux-container-palette label{margin-bottom:3px} diff --git a/library/admin/ReduxCore/inc/fields/palette/field_palette.js b/library/admin/ReduxCore/inc/fields/palette/field_palette.js deleted file mode 100644 index 001efcbd..00000000 --- a/library/admin/ReduxCore/inc/fields/palette/field_palette.js +++ /dev/null @@ -1,53 +0,0 @@ -/* - Field Palette (color) - */ - -/*global jQuery, document, redux_change, redux*/ - -(function( $ ) { - 'use strict'; - - redux.field_objects = redux.field_objects || {}; - redux.field_objects.palette = redux.field_objects.palette || {}; - - redux.field_objects.palette.init = function( selector ) { - - if ( !selector ) { - selector = $( document ).find( ".redux-group-tab:visible" ).find( '.redux-container-palette:visible' ); - } - - $( selector ).each( - function() { - - var el = $( this ); - var parent = el; - - if ( !el.hasClass( 'redux-field-container' ) ) { - parent = el.parents( '.redux-field-container:first' ); - } - - if ( parent.is( ":hidden" ) ) { // Skip hidden fields - return; - } - - if ( parent.hasClass( 'redux-field-init' ) ) { - parent.removeClass( 'redux-field-init' ); - } else { - return; - } - - el.find( '.buttonset' ).each( - function() { - $( this ).buttonset(); - } - ); - -// el.find('.redux-palette-set').click( -// function(){ -// console.log($(this).val()); -// } -// ) - } - ); - }; -})( jQuery ); \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/palette/field_palette.min.js b/library/admin/ReduxCore/inc/fields/palette/field_palette.min.js deleted file mode 100644 index 01209eb7..00000000 --- a/library/admin/ReduxCore/inc/fields/palette/field_palette.min.js +++ /dev/null @@ -1 +0,0 @@ -!function(a){"use strict";redux.field_objects=redux.field_objects||{},redux.field_objects.palette=redux.field_objects.palette||{},redux.field_objects.palette.init=function(b){b||(b=a(document).find(".redux-group-tab:visible").find(".redux-container-palette:visible")),a(b).each(function(){var b=a(this),c=b;b.hasClass("redux-field-container")||(c=b.parents(".redux-field-container:first")),c.is(":hidden")||c.hasClass("redux-field-init")&&(c.removeClass("redux-field-init"),b.find(".buttonset").each(function(){a(this).buttonset()}))})}}(jQuery); \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/palette/field_palette.php b/library/admin/ReduxCore/inc/fields/palette/field_palette.php deleted file mode 100644 index c1e364f3..00000000 --- a/library/admin/ReduxCore/inc/fields/palette/field_palette.php +++ /dev/null @@ -1,110 +0,0 @@ -. - * - * @package ReduxFramework - * @subpackage Field_Palette - * @author Kevin Provance (kprovance) - * @version 3.5.4 - */ - -// Exit if accessed directly -if ( ! defined( 'ABSPATH' ) ) { - exit; -} - -if ( ! class_exists( 'ReduxFramework_palette' ) ) { - class ReduxFramework_palette { - - /** - * Field Constructor. - * Required - must call the parent constructor, then assign field and value to vars, and obviously call the render field function - * - * @since 1.0.0 - * @access public - * @return void - */ - function __construct( $field = array(), $value = '', $parent ) { - $this->parent = $parent; - $this->field = $field; - $this->value = $value; - } - - /** - * Field Render Function. - * Takes the vars and outputs the HTML for the field in the settingss - * - * @since 1.0.0 - * @access public - * @return void - */ - public function render() { - if (empty($this->field['palettes'])) { - echo 'No palettes have been set.'; - return; - } - - echo '
    '; - - foreach ( $this->field['palettes'] as $value => $colorSet ) { - $checked = checked( $this->value , $value, false ); - echo ''; - echo ''; - echo ''; - } - - echo '
    '; - } - - /** - * Enqueue Function. - * If this field requires any scripts, or css define this function and register/enqueue the scripts/css - * - * @since 1.0.0 - * @access public - * @return void - */ - public function enqueue() { - $min = Redux_Functions::isMin(); - - wp_enqueue_script( - 'redux-field-palette-js', - ReduxFramework::$_url . 'inc/fields/palette/field_palette' . $min . '.js', - array( 'jquery', 'redux-js', 'jquery-ui-button', 'jquery-ui-core' ), - time(), - true - ); - - if ($this->parent->args['dev_mode']) { - wp_enqueue_style( - 'redux-field-palette-css', - ReduxFramework::$_url . 'inc/fields/palette/field_palette.css', - array(), - time(), - 'all' - ); - } - } - - - public function output() { - - } - } -} \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/palette/field_palette.scss b/library/admin/ReduxCore/inc/fields/palette/field_palette.scss deleted file mode 100644 index 7f6a8f46..00000000 --- a/library/admin/ReduxCore/inc/fields/palette/field_palette.scss +++ /dev/null @@ -1,55 +0,0 @@ -.redux-container-palette { - label { - border: 3px solid transparent; - border-color: transparent !important; - border-radius: 0; - //border: 0; - width: 100% !important; - display: block; - &.ui-button.ui-widget { - width: 95%; - background: none; - padding: 0; - - .ui-button-text { -/* border-top: 3px solid transparent; - border-bottom: 3px solid transparent; - margin-bottom: 5px;*/ - display: flex; - - span { - padding: 10px; - flex-grow: 1; - font-size: 0; - line-height: 10px; - color: rgba(0,0,0,0); - -webkit-transition: all 200ms ease-in-out; - -moz-transition: all 200ms ease-in-out; - -ms-transition: all 200ms ease-in-out; - -o-transition: all 200ms ease-in-out; - transition: all 200ms ease-in-out; - text-shadow: 0; - &:hover { - flex-grow: 3; - font-weight: bold; - min-width: 60px; - font-size: 12px; - line-height: 10px; - color: #333; - text-shadow: 0 0 8px #fff, 0 0 8px #fff; - } - } - } - } - - &.ui-state-active { - border: 3px solid #333 !important; - } - } -} - -.wp-customizer { - .redux-main .redux-container-palette label { - margin-bottom: 3px; - } -} \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/password/field_password.php b/library/admin/ReduxCore/inc/fields/password/field_password.php deleted file mode 100644 index 0e56e846..00000000 --- a/library/admin/ReduxCore/inc/fields/password/field_password.php +++ /dev/null @@ -1,106 +0,0 @@ -parent = $parent; - $this->field = $field; - $this->value = $value; - } - - /** - * Field Render Function. - * Takes the vars and outputs the HTML for the field in the settings - * - * @since ReduxFramework 1.0.1 - */ - function render() { - if ( ! empty( $this->field['username'] ) && $this->field['username'] === true ) { - $this->_render_combined_field(); - } else { - $this->_render_single_field(); - } - } - - /** - * This will render a combined User/Password field - * - * @since ReduxFramework 3.0.9 - * @example - * - * array( - * 'id' => 'smtp_account', - * 'type' => 'password', - * 'username' => true, - * 'title' => 'SMTP Account', - * 'placeholder' => array('username' => 'Username') - * ) - * - */ - private function _render_combined_field() { - - $defaults = array( - 'username' => '', - 'password' => '', - 'placeholder' => array( - 'password' => __( 'Password', 'redux-framework' ), - 'username' => __( 'Username', 'redux-framework' ) - ) - ); - - $this->value = wp_parse_args( $this->value, $defaults ); - - if ( ! empty( $this->field['placeholder'] ) ) { - if ( is_array( $this->field['placeholder'] ) ) { - if ( ! empty( $this->field['placeholder']['password'] ) ) { - $this->value['placeholder']['password'] = $this->field['placeholder']['password']; - } - if ( ! empty( $this->field['placeholder']['username'] ) ) { - $this->value['placeholder']['username'] = $this->field['placeholder']['username']; - } - } else { - $this->value['placeholder']['password'] = $this->field['placeholder']; - } - } - - // Username field - echo ' '; - - // Password field - echo ''; - } - - /** - * This will render a single Password field - * - * @since ReduxFramework 3.0.9 - * @example - * - * array( - * 'id' => 'smtp_password', - * 'type' => 'password', - * 'title' => 'SMTP Password' - * ) - * - */ - private function _render_single_field() { - echo ''; - } - } - } \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/radio/field_radio.php b/library/admin/ReduxCore/inc/fields/radio/field_radio.php deleted file mode 100644 index 75448566..00000000 --- a/library/admin/ReduxCore/inc/fields/radio/field_radio.php +++ /dev/null @@ -1,57 +0,0 @@ -parent = $parent; - $this->field = $field; - $this->value = $value; - } - - /** - * Field Render Function. - * Takes the vars and outputs the HTML for the field in the settings - * - * @since ReduxFramework 1.0.0 - */ - function render() { - - if ( ! empty( $this->field['data'] ) && empty( $this->field['options'] ) ) { - if ( empty( $this->field['args'] ) ) { - $this->field['args'] = array(); - } - $this->field['options'] = $this->parent->get_wordpress_data( $this->field['data'], $this->field['args'] ); - } - - $this->field['data_class'] = ( isset( $this->field['multi_layout'] ) ) ? 'data-' . $this->field['multi_layout'] : 'data-full'; - - if ( ! empty( $this->field['options'] ) ) { - echo '
      '; - - foreach ( $this->field['options'] as $k => $v ) { - echo '
    • '; - echo ''; - echo '
    • '; - } - //foreach - - echo '
    '; - } - } //function - } //class - } \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/raw/field_raw.php b/library/admin/ReduxCore/inc/fields/raw/field_raw.php deleted file mode 100644 index 3b3e5f6e..00000000 --- a/library/admin/ReduxCore/inc/fields/raw/field_raw.php +++ /dev/null @@ -1,53 +0,0 @@ -parent = $parent; - $this->field = $field; - $this->value = $value; - } - - /** - * Field Render Function. - * Takes the vars and outputs the HTML for the field in the settings - * - * @since ReduxFramework 1.0.0 - */ - function render() { - - if ( ! empty( $this->field['include'] ) && file_exists( $this->field['include'] ) ) { - require_once $this->field['include']; - } - - if ( isset( $this->field['content_path'] ) && ! empty( $this->field['content_path'] ) && file_exists( $this->field['content_path'] ) ) { - $this->field['content'] = $this->parent->filesystem->execute( 'get_contents', $this->field['content_path'] ); - } - - if ( ! empty( $this->field['content'] ) && isset( $this->field['content'] ) ) { - if ( isset( $this->field['markdown'] ) && $this->field['markdown'] == true ) { - require_once dirname( __FILE__ ) . "/parsedown.php"; - $Parsedown = new Parsedown(); - echo $Parsedown->text( $this->field['content'] ); - } else { - echo $this->field['content']; - } - } - - do_action( 'redux-field-raw-' . $this->parent->args['opt_name'] . '-' . $this->field['id'] ); - - } - } - } \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/raw/parsedown.php b/library/admin/ReduxCore/inc/fields/raw/parsedown.php deleted file mode 100644 index 1cfc779f..00000000 --- a/library/admin/ReduxCore/inc/fields/raw/parsedown.php +++ /dev/null @@ -1,1285 +0,0 @@ -Definitions = array(); - - # standardize line breaks - $text = str_replace( "\r\n", "\n", $text ); - $text = str_replace( "\r", "\n", $text ); - - # replace tabs with spaces - $text = str_replace( "\t", ' ', $text ); - - # remove surrounding line breaks - $text = trim( $text, "\n" ); - - # split text into lines - $lines = explode( "\n", $text ); - - # iterate through lines to identify blocks - $markup = $this->lines( $lines ); - - # trim line breaks - $markup = trim( $markup, "\n" ); - - return $markup; - } - - # - # Setters - # - - private $breaksEnabled; - - function setBreaksEnabled( $breaksEnabled ) { - $this->breaksEnabled = $breaksEnabled; - - return $this; - } - - # - # Lines - # - - protected $BlockTypes = array( - '#' => array( 'Atx' ), - '*' => array( 'Rule', 'List' ), - '+' => array( 'List' ), - '-' => array( 'Setext', 'Table', 'Rule', 'List' ), - '0' => array( 'List' ), - '1' => array( 'List' ), - '2' => array( 'List' ), - '3' => array( 'List' ), - '4' => array( 'List' ), - '5' => array( 'List' ), - '6' => array( 'List' ), - '7' => array( 'List' ), - '8' => array( 'List' ), - '9' => array( 'List' ), - ':' => array( 'Table' ), - '<' => array( 'Comment', 'Markup' ), - '=' => array( 'Setext' ), - '>' => array( 'Quote' ), - '_' => array( 'Rule' ), - '`' => array( 'FencedCode' ), - '|' => array( 'Table' ), - '~' => array( 'FencedCode' ), - ); - - # ~ - - protected $DefinitionTypes = array( - '[' => array( 'Reference' ), - ); - - # ~ - - protected $unmarkedBlockTypes = array( - 'CodeBlock', - ); - - # - # Blocks - # - - private function lines( array $lines ) { - $CurrentBlock = null; - - foreach ( $lines as $line ) { - if ( chop( $line ) === '' ) { - if ( isset( $CurrentBlock ) ) { - $CurrentBlock['interrupted'] = true; - } - - continue; - } - - $indent = 0; - - while ( isset( $line[ $indent ] ) and $line[ $indent ] === ' ' ) { - $indent ++; - } - - $text = $indent > 0 ? substr( $line, $indent ) : $line; - - # ~ - - $Line = array( 'body' => $line, 'indent' => $indent, 'text' => $text ); - - # ~ - - if ( isset( $CurrentBlock['incomplete'] ) ) { - $Block = $this->{'addTo' . $CurrentBlock['type']}( $Line, $CurrentBlock ); - - if ( isset( $Block ) ) { - $CurrentBlock = $Block; - - continue; - } else { - if ( method_exists( $this, 'complete' . $CurrentBlock['type'] ) ) { - $CurrentBlock = $this->{'complete' . $CurrentBlock['type']}( $CurrentBlock ); - } - - unset( $CurrentBlock['incomplete'] ); - } - } - - # ~ - - $marker = $text[0]; - - if ( isset( $this->DefinitionTypes[ $marker ] ) ) { - foreach ( $this->DefinitionTypes[ $marker ] as $definitionType ) { - $Definition = $this->{'identify' . $definitionType}( $Line, $CurrentBlock ); - - if ( isset( $Definition ) ) { - $this->Definitions[ $definitionType ][ $Definition['id'] ] = $Definition['data']; - - continue 2; - } - } - } - - # ~ - - $blockTypes = $this->unmarkedBlockTypes; - - if ( isset( $this->BlockTypes[ $marker ] ) ) { - foreach ( $this->BlockTypes[ $marker ] as $blockType ) { - $blockTypes [] = $blockType; - } - } - - # - # ~ - - foreach ( $blockTypes as $blockType ) { - $Block = $this->{'identify' . $blockType}( $Line, $CurrentBlock ); - - if ( isset( $Block ) ) { - $Block['type'] = $blockType; - - if ( ! isset( $Block['identified'] ) ) { - $Elements [] = $CurrentBlock['element']; - - $Block['identified'] = true; - } - - if ( method_exists( $this, 'addTo' . $blockType ) ) { - $Block['incomplete'] = true; - } - - $CurrentBlock = $Block; - - continue 2; - } - } - - # ~ - - if ( isset( $CurrentBlock ) and ! isset( $CurrentBlock['type'] ) and ! isset( $CurrentBlock['interrupted'] ) ) { - $CurrentBlock['element']['text'] .= "\n" . $text; - } else { - $Elements [] = $CurrentBlock['element']; - - $CurrentBlock = $this->buildParagraph( $Line ); - - $CurrentBlock['identified'] = true; - } - } - - # ~ - - if ( isset( $CurrentBlock['incomplete'] ) and method_exists( $this, 'complete' . $CurrentBlock['type'] ) ) { - $CurrentBlock = $this->{'complete' . $CurrentBlock['type']}( $CurrentBlock ); - } - - # ~ - - $Elements [] = $CurrentBlock['element']; - - unset( $Elements[0] ); - - # ~ - - $markup = $this->elements( $Elements ); - - # ~ - - return $markup; - } - - # - # Atx - - protected function identifyAtx( $Line ) { - if ( isset( $Line['text'][1] ) ) { - $level = 1; - - while ( isset( $Line['text'][ $level ] ) and $Line['text'][ $level ] === '#' ) { - $level ++; - } - - $text = trim( $Line['text'], '# ' ); - - $Block = array( - 'element' => array( - 'name' => 'h' . $level, - 'text' => $text, - 'handler' => 'line', - ), - ); - - return $Block; - } - } - - # - # Code - - protected function identifyCodeBlock( $Line ) { - if ( $Line['indent'] >= 4 ) { - $text = substr( $Line['body'], 4 ); - - $Block = array( - 'element' => array( - 'name' => 'pre', - 'handler' => 'element', - 'text' => array( - 'name' => 'code', - 'text' => $text, - ), - ), - ); - - return $Block; - } - } - - protected function addToCodeBlock( $Line, $Block ) { - if ( $Line['indent'] >= 4 ) { - if ( isset( $Block['interrupted'] ) ) { - $Block['element']['text']['text'] .= "\n"; - - unset( $Block['interrupted'] ); - } - - $Block['element']['text']['text'] .= "\n"; - - $text = substr( $Line['body'], 4 ); - - $Block['element']['text']['text'] .= $text; - - return $Block; - } - } - - protected function completeCodeBlock( $Block ) { - $text = $Block['element']['text']['text']; - - $text = htmlspecialchars( $text, ENT_NOQUOTES, 'UTF-8' ); - - $Block['element']['text']['text'] = $text; - - return $Block; - } - - # - # Comment - - protected function identifyComment( $Line ) { - if ( isset( $Line['text'][3] ) and $Line['text'][3] === '-' and $Line['text'][2] === '-' and $Line['text'][1] === '!' ) { - $Block = array( - 'element' => $Line['body'], - ); - - if ( preg_match( '/-->$/', $Line['text'] ) ) { - $Block['closed'] = true; - } - - return $Block; - } - } - - protected function addToComment( $Line, array $Block ) { - if ( isset( $Block['closed'] ) ) { - return; - } - - $Block['element'] .= "\n" . $Line['body']; - - if ( preg_match( '/-->$/', $Line['text'] ) ) { - $Block['closed'] = true; - } - - return $Block; - } - - # - # Fenced Code - - protected function identifyFencedCode( $Line ) { - if ( preg_match( '/^([' . $Line['text'][0] . ']{3,})[ ]*([\w-]+)?[ ]*$/', $Line['text'], $matches ) ) { - $Element = array( - 'name' => 'code', - 'text' => '', - ); - - if ( isset( $matches[2] ) ) { - $class = 'language-' . $matches[2]; - - $Element['attributes'] = array( - 'class' => $class, - ); - } - - $Block = array( - 'char' => $Line['text'][0], - 'element' => array( - 'name' => 'pre', - 'handler' => 'element', - 'text' => $Element, - ), - ); - - return $Block; - } - } - - protected function addToFencedCode( $Line, $Block ) { - if ( isset( $Block['complete'] ) ) { - return; - } - - if ( isset( $Block['interrupted'] ) ) { - $Block['element']['text']['text'] .= "\n"; - - unset( $Block['interrupted'] ); - } - - if ( preg_match( '/^' . $Block['char'] . '{3,}[ ]*$/', $Line['text'] ) ) { - $Block['element']['text']['text'] = substr( $Block['element']['text']['text'], 1 ); - - $Block['complete'] = true; - - return $Block; - } - - $Block['element']['text']['text'] .= "\n" . $Line['body'];; - - return $Block; - } - - protected function completeFencedCode( $Block ) { - $text = $Block['element']['text']['text']; - - $text = htmlspecialchars( $text, ENT_NOQUOTES, 'UTF-8' ); - - $Block['element']['text']['text'] = $text; - - return $Block; - } - - # - # List - - protected function identifyList( $Line ) { - list( $name, $pattern ) = $Line['text'][0] <= '-' ? array( 'ul', '[*+-]' ) : array( 'ol', '[0-9]+[.]' ); - - if ( preg_match( '/^(' . $pattern . '[ ]+)(.*)/', $Line['text'], $matches ) ) { - $Block = array( - 'indent' => $Line['indent'], - 'pattern' => $pattern, - 'element' => array( - 'name' => $name, - 'handler' => 'elements', - ), - ); - - $Block['li'] = array( - 'name' => 'li', - 'handler' => 'li', - 'text' => array( - $matches[2], - ), - ); - - $Block['element']['text'] [] = &$Block['li']; - - return $Block; - } - } - - protected function addToList( $Line, array $Block ) { - if ( $Block['indent'] === $Line['indent'] and preg_match( '/^' . $Block['pattern'] . '[ ]+(.*)/', $Line['text'], $matches ) ) { - if ( isset( $Block['interrupted'] ) ) { - $Block['li']['text'] [] = ''; - - unset( $Block['interrupted'] ); - } - - unset( $Block['li'] ); - - $Block['li'] = array( - 'name' => 'li', - 'handler' => 'li', - 'text' => array( - $matches[1], - ), - ); - - $Block['element']['text'] [] = &$Block['li']; - - return $Block; - } - - if ( ! isset( $Block['interrupted'] ) ) { - $text = preg_replace( '/^[ ]{0,4}/', '', $Line['body'] ); - - $Block['li']['text'] [] = $text; - - return $Block; - } - - if ( $Line['indent'] > 0 ) { - $Block['li']['text'] [] = ''; - - $text = preg_replace( '/^[ ]{0,4}/', '', $Line['body'] ); - - $Block['li']['text'] [] = $text; - - unset( $Block['interrupted'] ); - - return $Block; - } - } - - # - # Quote - - protected function identifyQuote( $Line ) { - if ( preg_match( '/^>[ ]?(.*)/', $Line['text'], $matches ) ) { - $Block = array( - 'element' => array( - 'name' => 'blockquote', - 'handler' => 'lines', - 'text' => (array) $matches[1], - ), - ); - - return $Block; - } - } - - protected function addToQuote( $Line, array $Block ) { - if ( $Line['text'][0] === '>' and preg_match( '/^>[ ]?(.*)/', $Line['text'], $matches ) ) { - if ( isset( $Block['interrupted'] ) ) { - $Block['element']['text'] [] = ''; - - unset( $Block['interrupted'] ); - } - - $Block['element']['text'] [] = $matches[1]; - - return $Block; - } - - if ( ! isset( $Block['interrupted'] ) ) { - $Block['element']['text'] [] = $Line['text']; - - return $Block; - } - } - - # - # Rule - - protected function identifyRule( $Line ) { - if ( preg_match( '/^([' . $Line['text'][0] . '])([ ]{0,2}\1){2,}[ ]*$/', $Line['text'] ) ) { - $Block = array( - 'element' => array( - 'name' => 'hr' - ), - ); - - return $Block; - } - } - - # - # Setext - - protected function identifySetext( $Line, array $Block = null ) { - if ( ! isset( $Block ) or isset( $Block['type'] ) or isset( $Block['interrupted'] ) ) { - return; - } - - if ( chop( $Line['text'], $Line['text'][0] ) === '' ) { - $Block['element']['name'] = $Line['text'][0] === '=' ? 'h1' : 'h2'; - - return $Block; - } - } - - # - # Markup - - protected function identifyMarkup( $Line ) { - if ( preg_match( '/^<(\w[\w\d]*)(?:[ ][^>\/]*)?(\/?)[ ]*>/', $Line['text'], $matches ) ) { - if ( in_array( $matches[1], $this->textLevelElements ) ) { - return; - } - - $Block = array( - 'element' => $Line['body'], - ); - - if ( $matches[2] or $matches[1] === 'hr' or preg_match( '/<\/' . $matches[1] . '>[ ]*$/', $Line['text'] ) ) { - $Block['closed'] = true; - } else { - $Block['depth'] = 0; - $Block['name'] = $matches[1]; - } - - return $Block; - } - } - - protected function addToMarkup( $Line, array $Block ) { - if ( isset( $Block['closed'] ) ) { - return; - } - - if ( preg_match( '/<' . $Block['name'] . '([ ][^\/]+)?>/', $Line['text'] ) ) # opening tag - { - $Block['depth'] ++; - } - - if ( stripos( $Line['text'], '' ) !== false ) # closing tag - { - if ( $Block['depth'] > 0 ) { - $Block['depth'] --; - } else { - $Block['closed'] = true; - } - } - - $Block['element'] .= "\n" . $Line['body']; - - return $Block; - } - - # - # Table - - protected function identifyTable( $Line, array $Block = null ) { - if ( ! isset( $Block ) or isset( $Block['type'] ) or isset( $Block['interrupted'] ) ) { - return; - } - - if ( strpos( $Block['element']['text'], '|' ) !== false and chop( $Line['text'], ' -:|' ) === '' ) { - $alignments = array(); - - $divider = $Line['text']; - - $divider = trim( $divider ); - $divider = trim( $divider, '|' ); - - $dividerCells = explode( '|', $divider ); - - foreach ( $dividerCells as $dividerCell ) { - $dividerCell = trim( $dividerCell ); - - if ( $dividerCell === '' ) { - continue; - } - - $alignment = null; - - if ( $dividerCell[0] === ':' ) { - $alignment = 'left'; - } - - if ( substr( $dividerCell, - 1 ) === ':' ) { - $alignment = $alignment === 'left' ? 'center' : 'right'; - } - - $alignments [] = $alignment; - } - - # ~ - - $HeaderElements = array(); - - $header = $Block['element']['text']; - - $header = trim( $header ); - $header = trim( $header, '|' ); - - $headerCells = explode( '|', $header ); - - foreach ( $headerCells as $index => $headerCell ) { - $headerCell = trim( $headerCell ); - - $HeaderElement = array( - 'name' => 'th', - 'text' => $headerCell, - 'handler' => 'line', - ); - - if ( isset( $alignments[ $index ] ) ) { - $alignment = $alignments[ $index ]; - - $HeaderElement['attributes'] = array( - 'align' => $alignment, - ); - } - - $HeaderElements [] = $HeaderElement; - } - - # ~ - - $Block = array( - 'alignments' => $alignments, - 'identified' => true, - 'element' => array( - 'name' => 'table', - 'handler' => 'elements', - ), - ); - - $Block['element']['text'] [] = array( - 'name' => 'thead', - 'handler' => 'elements', - ); - - $Block['element']['text'] [] = array( - 'name' => 'tbody', - 'handler' => 'elements', - 'text' => array(), - ); - - $Block['element']['text'][0]['text'] [] = array( - 'name' => 'tr', - 'handler' => 'elements', - 'text' => $HeaderElements, - ); - - return $Block; - } - } - - protected function addToTable( $Line, array $Block ) { - if ( $Line['text'][0] === '|' or strpos( $Line['text'], '|' ) ) { - $Elements = array(); - - $row = $Line['text']; - - $row = trim( $row ); - $row = trim( $row, '|' ); - - $cells = explode( '|', $row ); - - foreach ( $cells as $index => $cell ) { - $cell = trim( $cell ); - - $Element = array( - 'name' => 'td', - 'handler' => 'line', - 'text' => $cell, - ); - - if ( isset( $Block['alignments'][ $index ] ) ) { - $Element['attributes'] = array( - 'align' => $Block['alignments'][ $index ], - ); - } - - $Elements [] = $Element; - } - - $Element = array( - 'name' => 'tr', - 'handler' => 'elements', - 'text' => $Elements, - ); - - $Block['element']['text'][1]['text'] [] = $Element; - - return $Block; - } - } - - # - # Definitions - # - - protected function identifyReference( $Line ) { - if ( preg_match( '/^\[(.+?)\]:[ ]*' . '<' . '?(\S+?)>?(?:[ ]+["\'(](.+)["\')])?[ ]*$/', $Line['text'], $matches ) ) { - $Definition = array( - 'id' => strtolower( $matches[1] ), - 'data' => array( - 'url' => $matches[2], - ), - ); - - if ( isset( $matches[3] ) ) { - $Definition['data']['title'] = $matches[3]; - } - - return $Definition; - } - } - - # - # ~ - # - - protected function buildParagraph( $Line ) { - $Block = array( - 'element' => array( - 'name' => 'p', - 'text' => $Line['text'], - 'handler' => 'line', - ), - ); - - return $Block; - } - - # - # ~ - # - - protected function element( array $Element ) { - $markup = '<' . $Element['name']; - - if ( isset( $Element['attributes'] ) ) { - foreach ( $Element['attributes'] as $name => $value ) { - $markup .= ' ' . $name . '="' . $value . '"'; - } - } - - if ( isset( $Element['text'] ) ) { - $markup .= '>'; - - if ( isset( $Element['handler'] ) ) { - $markup .= $this->$Element['handler']( $Element['text'] ); - } else { - $markup .= $Element['text']; - } - - $markup .= ''; - } else { - $markup .= ' />'; - } - - return $markup; - } - - protected function elements( array $Elements ) { - $markup = ''; - - foreach ( $Elements as $Element ) { - if ( $Element === null ) { - continue; - } - - $markup .= "\n"; - - if ( is_string( $Element ) ) # because of Markup - { - $markup .= $Element; - - continue; - } - - $markup .= $this->element( $Element ); - } - - $markup .= "\n"; - - return $markup; - } - - # - # Spans - # - - protected $SpanTypes = array( - '!' => array( 'Link' ), # ? - '&' => array( 'Ampersand' ), - '*' => array( 'Emphasis' ), - '/' => array( 'Url' ), - '<' => array( 'UrlTag', 'EmailTag', 'Tag', 'LessThan' ), - '[' => array( 'Link' ), - '_' => array( 'Emphasis' ), - '`' => array( 'InlineCode' ), - '~' => array( 'Strikethrough' ), - '\\' => array( 'EscapeSequence' ), - ); - - # ~ - - protected $spanMarkerList = '*_!&[spanMarkerList ) ) { - $marker = $excerpt[0]; - - $markerPosition += strpos( $remainder, $marker ); - - $Excerpt = array( 'text' => $excerpt, 'context' => $text ); - - foreach ( $this->SpanTypes[ $marker ] as $spanType ) { - $handler = 'identify' . $spanType; - - $Span = $this->$handler( $Excerpt ); - - if ( ! isset( $Span ) ) { - continue; - } - - # The identified span can be ahead of the marker. - - if ( isset( $Span['position'] ) and $Span['position'] > $markerPosition ) { - continue; - } - - # Spans that start at the position of their marker don't have to set a position. - - if ( ! isset( $Span['position'] ) ) { - $Span['position'] = $markerPosition; - } - - $plainText = substr( $text, 0, $Span['position'] ); - - $markup .= $this->readPlainText( $plainText ); - - $markup .= isset( $Span['markup'] ) ? $Span['markup'] : $this->element( $Span['element'] ); - - $text = substr( $text, $Span['position'] + $Span['extent'] ); - - $remainder = $text; - - $markerPosition = 0; - - continue 2; - } - - $remainder = substr( $excerpt, 1 ); - - $markerPosition ++; - } - - $markup .= $this->readPlainText( $text ); - - return $markup; - } - - # - # ~ - # - - protected function identifyUrl( $Excerpt ) { - if ( ! isset( $Excerpt['text'][1] ) or $Excerpt['text'][1] !== '/' ) { - return; - } - - if ( preg_match( '/\bhttps?:[\/]{2}[^\s<]+\b\/*/ui', $Excerpt['context'], $matches, PREG_OFFSET_CAPTURE ) ) { - $url = str_replace( array( '&', '<' ), array( '&', '<' ), $matches[0][0] ); - - return array( - 'extent' => strlen( $matches[0][0] ), - 'position' => $matches[0][1], - 'element' => array( - 'name' => 'a', - 'text' => $url, - 'attributes' => array( - 'href' => $url, - ), - ), - ); - } - } - - protected function identifyAmpersand( $Excerpt ) { - if ( ! preg_match( '/^&#?\w+;/', $Excerpt['text'] ) ) { - return array( - 'markup' => '&', - 'extent' => 1, - ); - } - } - - protected function identifyStrikethrough( $Excerpt ) { - if ( ! isset( $Excerpt['text'][1] ) ) { - return; - } - - if ( $Excerpt['text'][1] === '~' and preg_match( '/^~~(?=\S)(.+?)(?<=\S)~~/', $Excerpt['text'], $matches ) ) { - return array( - 'extent' => strlen( $matches[0] ), - 'element' => array( - 'name' => 'del', - 'text' => $matches[1], - 'handler' => 'line', - ), - ); - } - } - - protected function identifyEscapeSequence( $Excerpt ) { - if ( isset( $Excerpt['text'][1] ) and in_array( $Excerpt['text'][1], $this->specialCharacters ) ) { - return array( - 'markup' => $Excerpt['text'][1], - 'extent' => 2, - ); - } - } - - protected function identifyLessThan() { - return array( - 'markup' => '<', - 'extent' => 1, - ); - } - - protected function identifyUrlTag( $Excerpt ) { - if ( strpos( $Excerpt['text'], '>' ) !== false and preg_match( '/^<(https?:[\/]{2}[^\s]+?)>/i', $Excerpt['text'], $matches ) ) { - $url = str_replace( array( '&', '<' ), array( '&', '<' ), $matches[1] ); - - return array( - 'extent' => strlen( $matches[0] ), - 'element' => array( - 'name' => 'a', - 'text' => $url, - 'attributes' => array( - 'href' => $url, - ), - ), - ); - } - } - - protected function identifyEmailTag( $Excerpt ) { - if ( strpos( $Excerpt['text'], '>' ) !== false and preg_match( '/^<(\S+?@\S+?)>/', $Excerpt['text'], $matches ) ) { - return array( - 'extent' => strlen( $matches[0] ), - 'element' => array( - 'name' => 'a', - 'text' => $matches[1], - 'attributes' => array( - 'href' => 'mailto:' . $matches[1], - ), - ), - ); - } - } - - protected function identifyTag( $Excerpt ) { - if ( strpos( $Excerpt['text'], '>' ) !== false and preg_match( '/^<\/?\w.*?>/', $Excerpt['text'], $matches ) ) { - return array( - 'markup' => $matches[0], - 'extent' => strlen( $matches[0] ), - ); - } - } - - protected function identifyInlineCode( $Excerpt ) { - $marker = $Excerpt['text'][0]; - - if ( preg_match( '/^(' . $marker . '+)[ ]*(.+?)[ ]*(? strlen( $matches[0] ), - 'element' => array( - 'name' => 'code', - 'text' => $text, - ), - ); - } - } - - protected function identifyLink( $Excerpt ) { - $extent = $Excerpt['text'][0] === '!' ? 1 : 0; - - if ( strpos( $Excerpt['text'], ']' ) and preg_match( '/\[((?:[^][]|(?R))*)\]/', $Excerpt['text'], $matches ) ) { - $Link = array( 'text' => $matches[1], 'label' => strtolower( $matches[1] ) ); - - $extent += strlen( $matches[0] ); - - $substring = substr( $Excerpt['text'], $extent ); - - if ( preg_match( '/^\s*\[([^][]+)\]/', $substring, $matches ) ) { - $Link['label'] = strtolower( $matches[1] ); - - if ( isset( $this->Definitions['Reference'][ $Link['label'] ] ) ) { - $Link += $this->Definitions['Reference'][ $Link['label'] ]; - - $extent += strlen( $matches[0] ); - } else { - return; - } - } elseif ( isset( $this->Definitions['Reference'][ $Link['label'] ] ) ) { - $Link += $this->Definitions['Reference'][ $Link['label'] ]; - - if ( preg_match( '/^[ ]*\[\]/', $substring, $matches ) ) { - $extent += strlen( $matches[0] ); - } - } elseif ( preg_match( '/^\([ ]*(.*?)(?:[ ]+[\'"](.+?)[\'"])?[ ]*\)/', $substring, $matches ) ) { - $Link['url'] = $matches[1]; - - if ( isset( $matches[2] ) ) { - $Link['title'] = $matches[2]; - } - - $extent += strlen( $matches[0] ); - } else { - return; - } - } else { - return; - } - - $url = str_replace( array( '&', '<' ), array( '&', '<' ), $Link['url'] ); - - if ( $Excerpt['text'][0] === '!' ) { - $Element = array( - 'name' => 'img', - 'attributes' => array( - 'alt' => $Link['text'], - 'src' => $url, - ), - ); - } else { - $Element = array( - 'name' => 'a', - 'handler' => 'line', - 'text' => $Link['text'], - 'attributes' => array( - 'href' => $url, - ), - ); - } - - if ( isset( $Link['title'] ) ) { - $Element['attributes']['title'] = $Link['title']; - } - - return array( - 'extent' => $extent, - 'element' => $Element, - ); - } - - protected function identifyEmphasis( $Excerpt ) { - if ( ! isset( $Excerpt['text'][1] ) ) { - return; - } - - $marker = $Excerpt['text'][0]; - - if ( $Excerpt['text'][1] === $marker and preg_match( $this->StrongRegex[ $marker ], $Excerpt['text'], $matches ) ) { - $emphasis = 'strong'; - } elseif ( preg_match( $this->EmRegex[ $marker ], $Excerpt['text'], $matches ) ) { - $emphasis = 'em'; - } else { - return; - } - - return array( - 'extent' => strlen( $matches[0] ), - 'element' => array( - 'name' => $emphasis, - 'handler' => 'line', - 'text' => $matches[1], - ), - ); - } - - # - # ~ - - protected function readPlainText( $text ) { - $breakMarker = $this->breaksEnabled ? "\n" : " \n"; - - $text = str_replace( $breakMarker, "
    \n", $text ); - - return $text; - } - - # - # ~ - # - - protected function li( $lines ) { - $markup = $this->lines( $lines ); - - $trimmedMarkup = trim( $markup ); - - if ( ! in_array( '', $lines ) and substr( $trimmedMarkup, 0, 3 ) === '

    ' ) { - $markup = $trimmedMarkup; - $markup = substr( $markup, 3 ); - - $position = strpos( $markup, "

    " ); - - $markup = substr_replace( $markup, '', $position, 4 ); - } - - return $markup; - } - - # - # Multiton - # - - static function instance( $name = 'default' ) { - if ( isset( self::$instances[ $name ] ) ) { - return self::$instances[ $name ]; - } - - $instance = new self(); - - self::$instances[ $name ] = $instance; - - return $instance; - } - - private static $instances = array(); - - # - # Deprecated Methods - # - - /** - * @deprecated in favor of "text" - */ - function parse( $text ) { - $markup = $this->text( $text ); - - return $markup; - } - - # - # Fields - # - - protected $Definitions; - - # - # Read-only - - protected $specialCharacters = array( - '\\', - '`', - '*', - '_', - '{', - '}', - '[', - ']', - '(', - ')', - '>', - '#', - '+', - '-', - '.', - '!', - ); - - protected $StrongRegex = array( - '*' => '/^[*]{2}((?:[^*]|[*][^*]*[*])+?)[*]{2}(?![*])/s', - '_' => '/^__((?:[^_]|_[^_]*_)+?)__(?!_)/us', - ); - - protected $EmRegex = array( - '*' => '/^[*]((?:[^*]|[*][*][^*]+?[*][*])+?)[*](?![*])/s', - '_' => '/^_((?:[^_]|__[^_]*__)+?)_(?!_)\b/us', - ); - - protected $textLevelElements = array( - 'a', - 'br', - 'bdo', - 'abbr', - 'blink', - 'nextid', - 'acronym', - 'basefont', - 'b', - 'em', - 'big', - 'cite', - 'small', - 'spacer', - 'listing', - 'i', - 'rp', - 'del', - 'code', - 'strike', - 'marquee', - 'q', - 'rt', - 'ins', - 'font', - 'strong', - 's', - 'tt', - 'sub', - 'mark', - 'u', - 'xm', - 'sup', - 'nobr', - 'var', - 'ruby', - 'wbr', - 'span', - 'time', - ); - } diff --git a/library/admin/ReduxCore/inc/fields/section/field_section.css b/library/admin/ReduxCore/inc/fields/section/field_section.css deleted file mode 100644 index 73a8cac1..00000000 --- a/library/admin/ReduxCore/inc/fields/section/field_section.css +++ /dev/null @@ -1 +0,0 @@ -.redux-main .form-table-section-indented{width:95%;margin-left:5%}.redux-main .form-table-section tr:first-of-type th:first-of-type{padding:0px !important}.redux-main h3{margin-top:10px}.redux-main .form-table-section-indented>tbody>tr:first-child{display:none}.redux-main .form-table-section-indented>tbody>tr:nth-last-child(2){border-bottom:0} diff --git a/library/admin/ReduxCore/inc/fields/section/field_section.php b/library/admin/ReduxCore/inc/fields/section/field_section.php deleted file mode 100644 index a0b4df7a..00000000 --- a/library/admin/ReduxCore/inc/fields/section/field_section.php +++ /dev/null @@ -1,130 +0,0 @@ -. - * - * @package ReduxFramework - * @subpackage Field_Section - * @author Tobias Karnetze (athoss.de) - * @version 1.0.0 - */ - -// Exit if accessed directly - if ( ! defined( 'ABSPATH' ) ) { - exit; - } - -// Don't duplicate me! - if ( ! class_exists( 'ReduxFramework_section' ) ) { - - /** - * Main ReduxFramework_heading class - * - * @since 1.0.0 - */ - class ReduxFramework_section { - - /** - * Field Constructor. - * Required - must call the parent constructor, then assign field and value to vars, and obviously call the render field function - * - * @since 1.0.0 - * @access public - * @return void - */ - public function __construct( $field = array(), $value = '', $parent ) { - $this->parent = $parent; - $this->field = $field; - $this->value = $value; - } - - /** - * Field Render Function. - * Takes the vars and outputs the HTML for the field in the settings - * - * @since 1.0.0 - * @access public - * @return void - */ - public function render() { - - // No errors please - $defaults = array( - 'indent' => '', - 'style' => '', - 'class' => '', - 'title' => '', - 'subtitle' => '', - ); - $this->field = wp_parse_args( $this->field, $defaults ); - - $guid = uniqid(); - - $add_class = ''; - if ( isset( $this->field['indent'] ) && true === $this->field['indent'] ) { - $add_class = ' form-table-section-indented'; - } elseif( !isset( $this->field['indent'] ) || ( isset( $this->field['indent'] ) && false !== $this->field['indent'] ) ) { - $add_class = " hide"; - } - - echo '
    '; - - echo '
    '; - - if ( ! empty( $this->field['title'] ) ) { - echo '

    ' . $this->field['title'] . '

    '; - } - - if ( ! empty( $this->field['subtitle'] ) ) { - echo '
    ' . $this->field['subtitle'] . '
    '; - } - - echo '
    '; - - // delete the tr afterwards - ?> - - parent->args['dev_mode'] ) { - wp_enqueue_style( - 'redux-field-section-css', - ReduxFramework::$_url . 'inc/fields/section/field_section.css', - array(), - time(), - 'all' - ); - } - } - } - } \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/section/field_section.scss b/library/admin/ReduxCore/inc/fields/section/field_section.scss deleted file mode 100644 index 2a70c87e..00000000 --- a/library/admin/ReduxCore/inc/fields/section/field_section.scss +++ /dev/null @@ -1,24 +0,0 @@ -.redux-main { - .form-table-section-indented { - width: 95%; - margin-left: 5%; - } - - .form-table-section tr:first-of-type th:first-of-type { - padding: 0px !important; - } - - h3 { - margin-top: 10px; - } - - .form-table-section-indented > tbody > tr{ - &:first-child { - display: none; - } - - &:nth-last-child(2) { - border-bottom: 0; - } - } -} \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/select/elusive-icons.php b/library/admin/ReduxCore/inc/fields/select/elusive-icons.php deleted file mode 100644 index a10d6761..00000000 --- a/library/admin/ReduxCore/inc/fields/select/elusive-icons.php +++ /dev/null @@ -1,312 +0,0 @@ - 0 ) { - var select2_params = $( this ).siblings( '.select2_params' ).val(); - select2_params = JSON.parse( select2_params ); - default_params = $.extend( {}, default_params, select2_params ); - } - - if ( $( this ).hasClass( 'font-icons' ) ) { - default_params = $.extend( - {}, { - formatResult: redux.field_objects.select.addIcon, - formatSelection: redux.field_objects.select.addIcon, - escapeMarkup: function( m ) { - return m; - } - }, default_params - ); - } - - $( this ).select2( default_params ); - - if ( $( this ).hasClass( 'select2-sortable' ) ) { - default_params = {}; - default_params.bindOrder = 'sortableStop'; - default_params.sortableOptions = {placeholder: 'ui-state-highlight'}; - $( this ).select2Sortable( default_params ); - } - - $( this ).on( - "change", function() { - redux_change( $( $( this ) ) ); - $( this ).select2SortableOrder(); - } - ); - } - ); - } - ); - }; - - redux.field_objects.select.addIcon = function( icon ) { - if ( icon.hasOwnProperty( 'id' ) ) { - return "" + "  " + icon.text + ""; - } - }; -})( jQuery ); \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/select/field_select.min.js b/library/admin/ReduxCore/inc/fields/select/field_select.min.js deleted file mode 100644 index ed53d030..00000000 --- a/library/admin/ReduxCore/inc/fields/select/field_select.min.js +++ /dev/null @@ -1 +0,0 @@ -!function(a){"use strict";redux.field_objects=redux.field_objects||{},redux.field_objects.select=redux.field_objects.select||{},redux.field_objects.select.init=function(b){b||(b=a(document).find(".redux-container-select:visible")),a(b).each(function(){var b=a(this),c=b;b.hasClass("redux-field-container")||(c=b.parents(".redux-field-container:first")),c.is(":hidden")||c.hasClass("redux-field-init")&&(c.removeClass("redux-field-init"),b.find("select.redux-select-item").each(function(){var b={width:"resolve",triggerChange:!0,allowClear:!0};if("multiple"==a(this).attr("multiple")&&(b.width="100%"),a(this).siblings(".select2_params").size()>0){var c=a(this).siblings(".select2_params").val();c=JSON.parse(c),b=a.extend({},b,c)}a(this).hasClass("font-icons")&&(b=a.extend({},{formatResult:redux.field_objects.select.addIcon,formatSelection:redux.field_objects.select.addIcon,escapeMarkup:function(a){return a}},b)),a(this).select2(b),a(this).hasClass("select2-sortable")&&(b={},b.bindOrder="sortableStop",b.sortableOptions={placeholder:"ui-state-highlight"},a(this).select2Sortable(b)),a(this).on("change",function(){redux_change(a(a(this))),a(this).select2SortableOrder()})}))})},redux.field_objects.select.addIcon=function(a){return a.hasOwnProperty("id")?"  "+a.text+"":void 0}}(jQuery); \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/select/field_select.php b/library/admin/ReduxCore/inc/fields/select/field_select.php deleted file mode 100644 index 5958216e..00000000 --- a/library/admin/ReduxCore/inc/fields/select/field_select.php +++ /dev/null @@ -1,176 +0,0 @@ -parent = $parent; - $this->field = $field; - $this->value = $value; - } - - /** - * Field Render Function. - * Takes the vars and outputs the HTML for the field in the settings - * - * @since ReduxFramework 1.0.0 - */ - public function render() { - $sortable = ( isset( $this->field['sortable'] ) && $this->field['sortable'] ) ? ' select2-sortable"' : ""; - - if ( ! empty( $sortable ) ) { // Dummy proofing :P - $this->field['multi'] = true; - } - - if ( ! empty( $this->field['data'] ) && empty( $this->field['options'] ) ) { - if ( empty( $this->field['args'] ) ) { - $this->field['args'] = array(); - } - - if ( $this->field['data'] == "elusive-icons" || $this->field['data'] == "elusive-icon" || $this->field['data'] == "elusive" ) { - $icons_file = ReduxFramework::$_dir . 'inc/fields/select/elusive-icons.php'; - /** - * filter 'redux-font-icons-file}' - * - * @param array $icon_file File for the icons - */ - $icons_file = apply_filters( 'redux-font-icons-file', $icons_file ); - - /** - * filter 'redux/{opt_name}/field/font/icons/file' - * - * @param array $icon_file File for the icons - */ - $icons_file = apply_filters( "redux/{$this->parent->args['opt_name']}/field/font/icons/file", $icons_file ); - if ( file_exists( $icons_file ) ) { - require_once $icons_file; - } - } - - $this->field['options'] = $this->parent->get_wordpress_data( $this->field['data'], $this->field['args'] ); - } - - if ( ! empty( $this->field['data'] ) && ( $this->field['data'] == "elusive-icons" || $this->field['data'] == "elusive-icon" || $this->field['data'] == "elusive" ) ) { - $this->field['class'] .= " font-icons"; - } - //if - - if ( ! empty( $this->field['options'] ) ) { - $multi = ( isset( $this->field['multi'] ) && $this->field['multi'] ) ? ' multiple="multiple"' : ""; - - if ( ! empty( $this->field['width'] ) ) { - $width = ' style="' . $this->field['width'] . '"'; - } else { - $width = ' style="width: 40%;"'; - } - - $nameBrackets = ""; - if ( ! empty( $multi ) ) { - $nameBrackets = "[]"; - } - - $placeholder = ( isset( $this->field['placeholder'] ) ) ? esc_attr( $this->field['placeholder'] ) : __( 'Select an item', 'redux-framework' ); - - if ( isset( $this->field['select2'] ) ) { // if there are any let's pass them to js - $select2_params = json_encode( $this->field['select2'] ); - $select2_params = htmlspecialchars( $select2_params, ENT_QUOTES ); - - echo ''; - } - - if ( isset( $this->field['multi'] ) && $this->field['multi'] && isset( $this->field['sortable'] ) && $this->field['sortable'] && ! empty( $this->value ) && is_array( $this->value ) ) { - $origOption = $this->field['options']; - $this->field['options'] = array(); - - foreach ( $this->value as $value ) { - $this->field['options'][ $value ] = $origOption[ $value ]; - } - - if ( count( $this->field['options'] ) < count( $origOption ) ) { - foreach ( $origOption as $key => $value ) { - if ( ! in_array( $key, $this->field['options'] ) ) { - $this->field['options'][ $key ] = $value; - } - } - } - } - - $sortable = ( isset( $this->field['sortable'] ) && $this->field['sortable'] ) ? ' select2-sortable"' : ""; - - echo ''; - } else { - echo '' . __( 'No items of this type were found.', 'redux-framework' ) . ''; - } - } //function - - private function make_option($id, $value, $group_name = '') { - if ( is_array( $this->value ) ) { - $selected = ( is_array( $this->value ) && in_array( $id, $this->value ) ) ? ' selected="selected"' : ''; - } else { - $selected = selected( $this->value, $id, false ); - } - - echo ''; - } - - /** - * Enqueue Function. - * If this field requires any scripts, or css define this function and register/enqueue the scripts/css - * - * @since ReduxFramework 1.0.0 - */ - public function enqueue() { - wp_enqueue_style( 'select2-css' ); - - wp_enqueue_script( - 'redux-field-select-js', - ReduxFramework::$_url . 'inc/fields/select/field_select' . Redux_Functions::isMin() . '.js', - array( 'jquery', 'select2-js', 'redux-js' ), - time(), - true - ); - - if ($this->parent->args['dev_mode']) { - wp_enqueue_style( - 'redux-field-select-css', - ReduxFramework::$_url . 'inc/fields/select/field_select.css', - array(), - time(), - 'all' - ); - } - } //function - } //class -} \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/select/field_select.scss b/library/admin/ReduxCore/inc/fields/select/field_select.scss deleted file mode 100644 index 066386e7..00000000 --- a/library/admin/ReduxCore/inc/fields/select/field_select.scss +++ /dev/null @@ -1,9 +0,0 @@ -.redux-container-select { - li.ui-state-highlight { - height: 20px; - margin-top: 2px; - margin-left: 5px; - width: 64px; - margin-bottom: 0; - } -} \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/select_image/field_select_image.css b/library/admin/ReduxCore/inc/fields/select_image/field_select_image.css deleted file mode 100644 index b4a9459c..00000000 --- a/library/admin/ReduxCore/inc/fields/select_image/field_select_image.css +++ /dev/null @@ -1 +0,0 @@ -.redux-container-select_image{margin-top:2px;margin-left:5px;width:100%;margin-bottom:0}.redux-preview-image{max-height:250px;max-width:250px;padding:5px;margin-top:10px;border:1px solid #e3e3e3;background:#f7f7f7;-moz-border-radius:3px;-khtml-border-radius:3px;-webkit-border-radius:3px;border-radius:3px} diff --git a/library/admin/ReduxCore/inc/fields/select_image/field_select_image.js b/library/admin/ReduxCore/inc/fields/select_image/field_select_image.js deleted file mode 100644 index 296f41ec..00000000 --- a/library/admin/ReduxCore/inc/fields/select_image/field_select_image.js +++ /dev/null @@ -1,72 +0,0 @@ -/*global redux_change, redux*/ - -(function( $ ) { - "use strict"; - - redux.field_objects = redux.field_objects || {}; - redux.field_objects.select_image = redux.field_objects.select_image || {}; - - $( document ).ready( - function() { - //redux.field_objects.select_image.init(); - } - ); - - redux.field_objects.select_image.init = function( selector ) { - - if ( !selector ) { - selector = $( document ).find( ".redux-group-tab:visible" ).find( '.redux-container-select_image:visible' ); - } - - $( selector ).each( - function() { - var el = $( this ); - var parent = el; - if ( !el.hasClass( 'redux-field-container' ) ) { - parent = el.parents( '.redux-field-container:first' ); - } - if ( parent.is( ":hidden" ) ) { // Skip hidden fields - return; - } - if ( parent.hasClass( 'redux-field-init' ) ) { - parent.removeClass( 'redux-field-init' ); - } else { - return; - } - var default_params = { - width: 'resolve', - triggerChange: true, - allowClear: true - }; - - var select2_handle = el.find( '.redux-container-select_image' ).find( '.select2_params' ); - - if ( select2_handle.size() > 0 ) { - var select2_params = select2_handle.val(); - - select2_params = JSON.parse( select2_params ); - default_params = $.extend( {}, default_params, select2_params ); - } - - el.find( 'select.redux-select-images' ).select2( default_params ); - - el.find( '.redux-select-images' ).on( - 'change', function() { - var preview = $( this ).parents( '.redux-field:first' ).find( '.redux-preview-image' ); - - if ( $( this ).val() === "" ) { - preview.fadeOut( - 'medium', function() { - preview.attr( 'src', '' ); - } - ); - } else { - preview.attr( 'src', $( this ).val() ); - preview.fadeIn().css( 'visibility', 'visible' ); - } - } - ); - } - ); - }; -})( jQuery ); \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/select_image/field_select_image.min.js b/library/admin/ReduxCore/inc/fields/select_image/field_select_image.min.js deleted file mode 100644 index 613a6d88..00000000 --- a/library/admin/ReduxCore/inc/fields/select_image/field_select_image.min.js +++ /dev/null @@ -1 +0,0 @@ -!function(a){"use strict";redux.field_objects=redux.field_objects||{},redux.field_objects.select_image=redux.field_objects.select_image||{},a(document).ready(function(){}),redux.field_objects.select_image.init=function(b){b||(b=a(document).find(".redux-group-tab:visible").find(".redux-container-select_image:visible")),a(b).each(function(){var b=a(this),c=b;if(b.hasClass("redux-field-container")||(c=b.parents(".redux-field-container:first")),!c.is(":hidden")&&c.hasClass("redux-field-init")){c.removeClass("redux-field-init");var d={width:"resolve",triggerChange:!0,allowClear:!0},e=b.find(".redux-container-select_image").find(".select2_params");if(e.size()>0){var f=e.val();f=JSON.parse(f),d=a.extend({},d,f)}b.find("select.redux-select-images").select2(d),b.find(".redux-select-images").on("change",function(){var b=a(this).parents(".redux-field:first").find(".redux-preview-image");""===a(this).val()?b.fadeOut("medium",function(){b.attr("src","")}):(b.attr("src",a(this).val()),b.fadeIn().css("visibility","visible"))})}})}}(jQuery); \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/select_image/field_select_image.php b/library/admin/ReduxCore/inc/fields/select_image/field_select_image.php deleted file mode 100644 index 4f7c2eaa..00000000 --- a/library/admin/ReduxCore/inc/fields/select_image/field_select_image.php +++ /dev/null @@ -1,176 +0,0 @@ - - */ - -// Exit if accessed directly -if ( ! defined( 'ABSPATH' ) ) { - exit; -} - -if ( ! class_exists( 'ReduxFramework_select_image' ) ) { - class ReduxFramework_select_image { - - /** - * Field Constructor. - * Required - must call the parent constructor, then assign field and value to vars, and obviously call the render field function - * - * @since ReduxFramework 1.0.0 - */ - function __construct( $field = array(), $value = '', $parent ) { - $this->parent = $parent; - $this->field = $field; - $this->value = $value; - } - - /** - * Field Render Function. - * Takes the vars and outputs the HTML for the field in the settings - * - * @since ReduxFramework 1.0.0 - */ - function render() { - - // If options is NOT empty, the process - if ( ! empty( $this->field['options'] ) ) { - - // Strip off the file ext - if ( isset( $this->value ) ) { - $name = explode( ".", $this->value ); - $name = str_replace( '.' . end( $name ), '', $this->value ); - $name = basename( $name ); - //$this->value = trim( $name ); - $filename = trim($name); - } - - // beancounter - $x = 1; - - // Process width - if ( ! empty( $this->field['width'] ) ) { - $width = ' style="width:' . $this->field['width'] . ';"'; - } else { - $width = ' style="width: 40%;"'; - } - - // Process placeholder - $placeholder = ( isset( $this->field['placeholder'] ) ) ? esc_attr( $this->field['placeholder'] ) : __( 'Select an item', 'redux-framework' ); - - if ( isset( $this->field['select2'] ) ) { // if there are any let's pass them to js - $select2_params = json_encode( $this->field['select2'] ); - $select2_params = htmlspecialchars( $select2_params, ENT_QUOTES ); - - echo ''; - } - - // Begin the '; - echo ''; - - - // Enum through the options array - foreach ( $this->field['options'] as $k => $v ) { - - // No array? No problem! - if ( ! is_array( $v ) ) { - $v = array( 'img' => $v ); - } - - // No title set? Make it blank. - if ( ! isset( $v['title'] ) ) { - $v['title'] = ''; - } - - // No alt? Set it to title. We do this so the alt tag shows - // something. It also makes HTML/SEO purists happy. - if ( ! isset( $v['alt'] ) ) { - $v['alt'] = $v['title']; - } - - // Set the selected entry - $selected = selected( $this->value, $v['img'], false ); - - // If selected returns something other than a blank space, we - // found our default/saved name. Save the array number in a - // variable to use later on when we want to extract its associted - // url. - if ( '' != $selected ) { - $arrNum = $x; - } - - // Add the option tag, with values. - echo ''; - - // Add a bean - $x ++; - } - - // Close the '; - - // Some space - echo '

    '; - - // Show the preview image. - echo '
    '; - - // just in case. You never know. - if ( ! isset( $arrNum ) ) { - $this->value = ''; - } - - // Set the default image. To get the url from the default name, - // we save the array count from the for/each loop, when the default image - // is mark as selected. Since the for/each loop starts at one, we must - // substract one from the saved array number. We then pull the url - // out of the options array, and there we go. - if ( '' == $this->value ) { - echo ''; - } else { - echo ''; - } - - // Close the
    tag. - echo '
    '; - } else { - - // No options specified. Really? - echo '' . __( 'No items of this type were found.', 'redux-framework' ) . ''; - } - } //function - - /** - * Enqueue Function. - * If this field requires any scripts, or css define this function and register/enqueue the scripts/css - * - * @since ReduxFramework 1.0.0 - */ - function enqueue() { - wp_enqueue_style( 'select2-css' ); - - wp_enqueue_script( - 'field-select-image-js', - ReduxFramework::$_url . 'inc/fields/select_image/field_select_image' . Redux_Functions::isMin() . '.js', - array('jquery', 'select2-js', 'redux-js'), - time(), - true - ); - - if ($this->parent->args['dev_mode']) { - wp_enqueue_style( - 'redux-field-select-image-css', - ReduxFramework::$_url . 'inc/fields/select_image/field_select_image.css', - array(), - time(), - 'all' - ); - } - } //function - } //class -} \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/select_image/field_select_image.scss b/library/admin/ReduxCore/inc/fields/select_image/field_select_image.scss deleted file mode 100644 index 97e85972..00000000 --- a/library/admin/ReduxCore/inc/fields/select_image/field_select_image.scss +++ /dev/null @@ -1,19 +0,0 @@ -.redux-container-select_image { - margin-top: 2px; - margin-left: 5px; - width: 100%; - margin-bottom: 0; -} - -.redux-preview-image { - max-height: 250px; - max-width: 250px; - padding: 5px; - margin-top: 10px; - border: 1px solid #e3e3e3; - background: #f7f7f7; - -moz-border-radius: 3px; - -khtml-border-radius: 3px; - -webkit-border-radius: 3px; - border-radius: 3px; -} \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/slider/field_slider.css b/library/admin/ReduxCore/inc/fields/slider/field_slider.css deleted file mode 100644 index 6991456f..00000000 --- a/library/admin/ReduxCore/inc/fields/slider/field_slider.css +++ /dev/null @@ -1 +0,0 @@ -.redux-container-slider .redux-slider-container{margin-left:25px;margin-right:25px;width:200px;display:inline-block;vertical-align:middle}.redux-container-slider .redux-slider-input,.redux-container-slider .redux-slider-select-one,.redux-container-slider .redux-slider-select-two{width:100px !important;text-align:center}.redux-container-slider .redux-slider-label{position:absolute;margin-left:-5px}.redux-container-slider .redux-slider-label-one{position:absolute;margin-left:-22px}.redux-container-slider .redux-slider-label-two{position:absolute;margin-top:-21px;margin-left:245px}@media screen and (max-width: 782px){.redux-container-slider input{display:inline-block !important}}@media screen and (max-width: 570px){.redux-container-slider{text-align:center}.redux-container-slider input,.redux-container-slider select,.redux-container-slider .redux-slider-label,.redux-container-slider .select2-container{display:block !important;position:inherit;margin:10px auto}.redux-container-slider .redux-slider-container{margin-top:3px;width:80%}}.wp-customizer .redux-container-slider .redux-slider-label{float:left;position:inherit;width:25%;text-align:center;margin-left:0}.wp-customizer .redux-container-slider .redux-slider-input,.wp-customizer .redux-container-slider .redux-slider-select-one,.wp-customizer .redux-container-slider .redux-slider-select-two{width:25% !important}.wp-customizer .redux-container-slider .redux-slider-container{width:70%;margin-right:0;margin-left:5%} diff --git a/library/admin/ReduxCore/inc/fields/slider/field_slider.js b/library/admin/ReduxCore/inc/fields/slider/field_slider.js deleted file mode 100644 index 14040862..00000000 --- a/library/admin/ReduxCore/inc/fields/slider/field_slider.js +++ /dev/null @@ -1,269 +0,0 @@ -/*global redux_change, redux*/ - -(function( $ ) { - "use strict"; - - redux.field_objects = redux.field_objects || {}; - redux.field_objects.slider = redux.field_objects.slider || {}; - - $( document ).ready( - function() { - - } - ); - - redux.field_objects.slider.init = function( selector ) { - - if ( !selector ) { - selector = $( document ).find( ".redux-group-tab:visible" ).find( '.redux-container-slider:visible' ); - } - - $( selector ).each( - function() { - var el = $( this ); - var parent = el; - - if ( !el.hasClass( 'redux-field-container' ) ) { - parent = el.parents( '.redux-field-container:first' ); - } - if ( parent.is( ":hidden" ) ) { // Skip hidden fields - return; - } - if ( parent.hasClass( 'redux-field-init' ) ) { - parent.removeClass( 'redux-field-init' ); - } else { - return; - } - - el.find( 'div.redux-slider-container' ).each( - function() { - - var start, toClass, defClassOne, defClassTwo, connectVal; - var DISPLAY_NONE = 0; - var DISPLAY_LABEL = 1; - var DISPLAY_TEXT = 2; - var DISPLAY_SELECT = 3; - - var mainID = $( this ).data( 'id' ); - var minVal = $( this ).data( 'min' ); - var maxVal = $( this ).data( 'max' ); - var stepVal = $( this ).data( 'step' ); - var handles = $( this ).data( 'handles' ); - var defValOne = $( this ).data( 'default-one' ); - var defValTwo = $( this ).data( 'default-two' ); - var resVal = $( this ).data( 'resolution' ); - var displayValue = parseInt( ($( this ).data( 'display' )) ); - var rtlVal = Boolean( $( this ).data( 'rtl' ) ); - var floatMark = ($( this ).data( 'float-mark' )); - var forced = Boolean($( this ).data( 'forced' )); - - var rtl; - if ( rtlVal === true ) { - rtl = 'rtl'; - } else { - rtl = 'ltr'; - } - - // range array - var range = [minVal, maxVal]; - - // Set default values for dual slides. - var startTwo = [defValOne, defValTwo]; - - // Set default value for single slide - var startOne = [defValOne]; - - var inputOne, inputTwo; - if ( displayValue == DISPLAY_TEXT ) { - defClassOne = el.find( '.redux-slider-input-one-' + mainID ); - defClassTwo = el.find( '.redux-slider-input-two-' + mainID ); - - inputOne = defClassOne; - inputTwo = defClassTwo; - } else if ( displayValue == DISPLAY_SELECT ) { - defClassOne = el.find( '.redux-slider-select-one-' + mainID ); - defClassTwo = el.find( '.redux-slider-select-two-' + mainID ); - - redux.field_objects.slider.loadSelect( defClassOne, minVal, maxVal, resVal, stepVal ); - - if ( handles === 2 ) { - redux.field_objects.slider.loadSelect( defClassTwo, minVal, maxVal, resVal, stepVal ); - } - - } else if ( displayValue == DISPLAY_LABEL ) { - defClassOne = el.find( '#redux-slider-label-one-' + mainID ); - defClassTwo = el.find( '#redux-slider-label-two-' + mainID ); - } else if ( displayValue == DISPLAY_NONE ) { - defClassOne = el.find( '.redux-slider-value-one-' + mainID ); - defClassTwo = el.find( '.redux-slider-value-two-' + mainID ); - } - - var classOne, classTwo; - if ( displayValue == DISPLAY_LABEL ) { - var x = [defClassOne, 'html']; - var y = [defClassTwo, 'html']; - - classOne = [x]; - classTwo = [x, y]; - } else { - classOne = [defClassOne]; - classTwo = [defClassOne, defClassTwo]; - } - - if ( handles === 2 ) { - start = startTwo; - toClass = classTwo; - connectVal = true; - } else { - start = startOne; - toClass = classOne; - connectVal = 'lower'; - } - - var slider = $( this ).noUiSlider( - { - range: range, - start: start, - handles: handles, - step: stepVal, - connect: connectVal, - behaviour: "tap-drag", - direction: rtl, - serialization: { - resolution: resVal, - to: toClass, - mark: floatMark, - }, - slide: function() { - if ( displayValue == DISPLAY_LABEL ) { - if ( handles === 2 ) { - var inpSliderVal = slider.val(); - el.find( 'input.redux-slider-value-one-' + mainID ).attr( - 'value', inpSliderVal[0] - ); - el.find( 'input.redux-slider-value-two-' + mainID ).attr( - 'value', inpSliderVal[1] - ); - } else { - el.find( 'input.redux-slider-value-one-' + mainID ).attr( - 'value', slider.val() - ); - } - } - - if ( displayValue == DISPLAY_SELECT ) { - if ( handles === 2 ) { - el.find( '.redux-slider-select-one' ).select2( 'val', slider.val()[0] ); - el.find( '.redux-slider-select-two' ).select2( 'val', slider.val()[1] ); - } else { - el.find( '.redux-slider-select-one' ).select2( 'val', slider.val() ); - } - } - - redux_change( $( this ).parents( '.redux-field-container:first' ).find( 'input' ) ); - } - } - ); - - if ( displayValue === DISPLAY_TEXT ) { - inputOne.keydown( - function( e ) { - - var sliderOne = slider.val(); - var value = parseInt( sliderOne[0] ); - - switch ( e.which ) { - case 38: - slider.val( [value + 1, null] ); - break; - case 40: - slider.val( [value - 1, null] ); - break; - case 13: - e.preventDefault(); - break; - } - } - ); - - if ( handles === 2 ) { - inputTwo.keydown( - function( e ) { - var sliderTwo = slider.val(); - var value = parseInt( sliderTwo[1] ); - - switch ( e.which ) { - case 38: - slider.val( [null, value + 1] ); - break; - case 40: - slider.val( [null, value - 1] ); - break; - case 13: - e.preventDefault(); - break; - } - } - ); - } - } - } - ); - - var default_params = { - width: 'resolve', - triggerChange: true, - allowClear: true - }; - - var select2_handle = el.find( '.select2_params' ); - if ( select2_handle.size() > 0 ) { - var select2_params = select2_handle.val(); - - select2_params = JSON.parse( select2_params ); - default_params = $.extend( {}, default_params, select2_params ); - } - - el.find( 'select.redux-slider-select-one, select.redux-slider-select-two' ).select2( default_params ); - - } - ); - - }; - - // Return true for float value, false otherwise - redux.field_objects.slider.isFloat = function( mixed_var ) { - return +mixed_var === mixed_var && (!(isFinite( mixed_var ))) || Boolean( (mixed_var % 1) ); - }; - - // Return number of integers after the decimal point. - redux.field_objects.slider.decimalCount = function( res ) { - var q = res.toString().split( '.' ); - return q[1].length; - }; - - redux.field_objects.slider.loadSelect = function( myClass, min, max, res, step ) { - - //var j = step + ((decCount ) - (step )); // 18; - - for ( var i = min; i <= max; i = i + res ) { - //var step = 2; - - //if (j === (step + ((decCount ) - (step )))) { - var n = i; - if ( redux.field_objects.slider.isFloat( res ) ) { - var decCount = redux.field_objects.slider.decimalCount( res ); - n = i.toFixed( decCount ); - } - - $( myClass ).append( - '' - ); - //j = 0; - //} - //j++; - } - }; - - -})( jQuery ); diff --git a/library/admin/ReduxCore/inc/fields/slider/field_slider.min.js b/library/admin/ReduxCore/inc/fields/slider/field_slider.min.js deleted file mode 100644 index a343cbe4..00000000 --- a/library/admin/ReduxCore/inc/fields/slider/field_slider.min.js +++ /dev/null @@ -1 +0,0 @@ -!function(a){"use strict";redux.field_objects=redux.field_objects||{},redux.field_objects.slider=redux.field_objects.slider||{},a(document).ready(function(){}),redux.field_objects.slider.init=function(b){b||(b=a(document).find(".redux-group-tab:visible").find(".redux-container-slider:visible")),a(b).each(function(){var b=a(this),c=b;if(b.hasClass("redux-field-container")||(c=b.parents(".redux-field-container:first")),!c.is(":hidden")&&c.hasClass("redux-field-init")){c.removeClass("redux-field-init"),b.find("div.redux-slider-container").each(function(){var c,d,e,f,g,h,i=0,j=1,k=2,l=3,m=a(this).data("id"),n=a(this).data("min"),o=a(this).data("max"),p=a(this).data("step"),q=a(this).data("handles"),r=a(this).data("default-one"),s=a(this).data("default-two"),t=a(this).data("resolution"),u=parseInt(a(this).data("display")),v=Boolean(a(this).data("rtl")),w=a(this).data("float-mark");Boolean(a(this).data("forced"));h=v===!0?"rtl":"ltr";var x,y,z=[n,o],A=[r,s],B=[r];u==k?(e=b.find(".redux-slider-input-one-"+m),f=b.find(".redux-slider-input-two-"+m),x=e,y=f):u==l?(e=b.find(".redux-slider-select-one-"+m),f=b.find(".redux-slider-select-two-"+m),redux.field_objects.slider.loadSelect(e,n,o,t,p),2===q&&redux.field_objects.slider.loadSelect(f,n,o,t,p)):u==j?(e=b.find("#redux-slider-label-one-"+m),f=b.find("#redux-slider-label-two-"+m)):u==i&&(e=b.find(".redux-slider-value-one-"+m),f=b.find(".redux-slider-value-two-"+m));var C,D;if(u==j){var E=[e,"html"],F=[f,"html"];C=[E],D=[E,F]}else C=[e],D=[e,f];2===q?(c=A,d=D,g=!0):(c=B,d=C,g="lower");var G=a(this).noUiSlider({range:z,start:c,handles:q,step:p,connect:g,behaviour:"tap-drag",direction:h,serialization:{resolution:t,to:d,mark:w},slide:function(){if(u==j)if(2===q){var c=G.val();b.find("input.redux-slider-value-one-"+m).attr("value",c[0]),b.find("input.redux-slider-value-two-"+m).attr("value",c[1])}else b.find("input.redux-slider-value-one-"+m).attr("value",G.val());u==l&&(2===q?(b.find(".redux-slider-select-one").select2("val",G.val()[0]),b.find(".redux-slider-select-two").select2("val",G.val()[1])):b.find(".redux-slider-select-one").select2("val",G.val())),redux_change(a(this).parents(".redux-field-container:first").find("input"))}});u===k&&(x.keydown(function(a){var b=G.val(),c=parseInt(b[0]);switch(a.which){case 38:G.val([c+1,null]);break;case 40:G.val([c-1,null]);break;case 13:a.preventDefault()}}),2===q&&y.keydown(function(a){var b=G.val(),c=parseInt(b[1]);switch(a.which){case 38:G.val([null,c+1]);break;case 40:G.val([null,c-1]);break;case 13:a.preventDefault()}}))});var d={width:"resolve",triggerChange:!0,allowClear:!0},e=b.find(".select2_params");if(e.size()>0){var f=e.val();f=JSON.parse(f),d=a.extend({},d,f)}b.find("select.redux-slider-select-one, select.redux-slider-select-two").select2(d)}})},redux.field_objects.slider.isFloat=function(a){return+a===a&&!isFinite(a)||Boolean(a%1)},redux.field_objects.slider.decimalCount=function(a){var b=a.toString().split(".");return b[1].length},redux.field_objects.slider.loadSelect=function(b,c,d,e,f){for(var g=c;d>=g;g+=e){var h=g;if(redux.field_objects.slider.isFloat(e)){var i=redux.field_objects.slider.decimalCount(e);h=g.toFixed(i)}a(b).append('")}}}(jQuery); \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/slider/field_slider.php b/library/admin/ReduxCore/inc/fields/slider/field_slider.php deleted file mode 100644 index 5b25e490..00000000 --- a/library/admin/ReduxCore/inc/fields/slider/field_slider.php +++ /dev/null @@ -1,414 +0,0 @@ -. - * - * @package ReduxFramework - * @subpackage Field_Slider - * @author Kevin Provance (kprovance) - * @version 2.0.0 - */ - -// Exit if accessed directly -if ( ! defined( 'ABSPATH' ) ) { - exit; -} - -if ( ! class_exists( 'ReduxFramework_slider' ) ) { - class ReduxFramework_slider { - - /** - * Field Constructor. - * Required - must call the parent constructor, then assign field and value to vars, and obviously call the render field function - * - * @since ReduxFramework 3.1.8 - */ - private $display_none = 0; - private $display_label = 1; - private $display_text = 2; - private $display_select = 3; - - function __construct( $field = array(), $value = '', $parent ) { - - //parent::__construct( $parent->sections, $parent->args ); - $this->parent = $parent; - $this->field = $field; - $this->value = $value; - - // Set defaults - $defaults = array( - 'handles' => 1, - 'resolution' => 1, - 'display_value' => 'text', - 'float_mark' => '.', - 'forced' => true - ); - - $this->field = wp_parse_args( $this->field, $defaults ); - - // Sanitize float mark - switch ( $this->field['float_mark'] ) { - case ',': - case '.': - break; - default: - $this->field['float_mark'] = '.'; - break; - } - - // Sanitize resolution value - $this->field['resolution'] = $this->cleanVal( $this->field['resolution'] ); - - // Sanitize handle value - switch ( $this->field['handles'] ) { - case 0: - case 1: - $this->field['handles'] = 1; - break; - default: - $this->field['handles'] = 2; - break; - } - - // Sanitize display value - switch ( $this->field['display_value'] ) { - case 'label': - $this->field['display_value'] = $this->display_label; - break; - case 'text': - default: - $this->field['display_value'] = $this->display_text; - break; - case 'select': - $this->field['display_value'] = $this->display_select; - break; - case 'none': - $this->field['display_value'] = $this->display_none; - break; - } - } - - private function cleanVal( $var ) { - if ( is_float( $var ) ) { - $cleanVar = floatval( $var ); - } else { - $cleanVar = intval( $var ); - } - - return $cleanVar; - } - - private function cleanDefault( $val ) { - if ( empty( $val ) && ! empty( $this->field['default'] ) && $this->cleanVal( $this->field['min'] ) >= 1 ) { - $val = $this->cleanVal( $this->field['default'] ); - } - - if ( empty( $val ) && $this->cleanVal( $this->field['min'] ) >= 1 ) { - $val = $this->cleanVal( $this->field['min'] ); - } - - if ( empty( $val ) ) { - $val = 0; - } - - // Extra Validation - if ( $val < $this->field['min'] ) { - $val = $this->cleanVal( $this->field['min'] ); - } else if ( $val > $this->field['max'] ) { - $val = $this->cleanVal( $this->field['max'] ); - } - - return $val; - } - - private function cleanDefaultArray( $val ) { - $one = $this->value[1]; - $two = $this->value[2]; - - if ( empty( $one ) && ! empty( $this->field['default'][1] ) && $this->cleanVal( $this->field['min'] ) >= 1 ) { - $one = $this->cleanVal( $this->field['default'][1] ); - } - - if ( empty( $one ) && $this->cleanVal( $this->field['min'] ) >= 1 ) { - $one = $this->cleanVal( $this->field['min'] ); - } - - if ( empty( $one ) ) { - $one = 0; - } - - if ( empty( $two ) && ! empty( $this->field['default'][2] ) && $this->cleanVal( $this->field['min'] ) >= 1 ) { - $two = $this->cleanVal( $this->field['default'][1] + 1 ); - } - - if ( empty( $two ) && $this->cleanVal( $this->field['min'] ) >= 1 ) { - $two = $this->cleanVal( $this->field['default'][1] + 1 ); - } - - if ( empty( $two ) ) { - $two = $this->field['default'][1] + 1; - } - - $val[0] = $one; - $val[1] = $two; - - return $val; - } - - - /** - * Clean the field data to the fields defaults given the parameters. - * - * @since Redux_Framework 3.1.8 - */ - function clean() { - - // Set min to 0 if no value is set. - $this->field['min'] = empty( $this->field['min'] ) ? 0 : $this->cleanVal( $this->field['min'] ); - - // Set max to min + 1 if empty. - $this->field['max'] = empty( $this->field['max'] ) ? $this->field['min'] + 1 : $this->cleanVal( $this->field['max'] ); - - // Set step to 1 if step is empty ot step > max. - $this->field['step'] = empty( $this->field['step'] ) || $this->field['step'] > $this->field['max'] ? 1 : $this->cleanVal( $this->field['step'] ); - - if ( 2 == $this->field['handles'] ) { - if ( ! is_array( $this->value ) ) { - $this->value[1] = 0; - $this->value[2] = 1; - } - $this->value = $this->cleanDefaultArray( $this->value ); - } else { - if ( is_array( $this->value ) ) { - $this->value = 0; - } - $this->value = $this->cleanDefault( $this->value ); - } - - // More dummy checks - //if ( ! is_array( $this->field['default'] ) && 2 == $this->field['handles'] ) { - if ( ! is_array( $this->value ) && 2 == $this->field['handles'] ) { - $this->value[0] = $this->field['min']; - $this->value[1] = $this->field['min'] + 1; - } - - //if ( is_array( $this->field['default'] ) && 1 == $this->field['handles'] ) { - if ( is_array( $this->value ) && 1 == $this->field['handles'] ) { - $this->value = $this->field['min']; - } - - } - - /** - * Enqueue Function. - * If this field requires any scripts, or css define this function and register/enqueue the scripts/css - * - * @since ReduxFramework 3.1.8 - */ - function enqueue() { - - $min = Redux_Functions::isMin(); - - wp_enqueue_style( 'select2-css' ); - - wp_enqueue_style( - 'redux-nouislider-css', - ReduxFramework::$_url . 'inc/fields/slider/vendor/nouislider/redux.jquery.nouislider.css', - array(), - '5.0.0', - 'all' - ); - - wp_register_script( - 'redux-nouislider-js', - ReduxFramework::$_url . 'inc/fields/slider/vendor/nouislider/redux.jquery.nouislider' . $min . '.js', - array( 'jquery' ), - '5.0.0', - true - ); - - wp_enqueue_script( - 'redux-field-slider-js', - ReduxFramework::$_url . 'inc/fields/slider/field_slider' . $min . '.js', - array( 'jquery', 'redux-nouislider-js', 'redux-js', 'select2-js' ), - time(), - true - ); - - if ($this->parent->args['dev_mode']) { - wp_enqueue_style( - 'redux-field-slider-css', - ReduxFramework::$_url . 'inc/fields/slider/field_slider.css', - array(), - time(), - 'all' - ); - } - } - - //function - - /** - * Field Render Function. - * Takes the vars and outputs the HTML for the field in the settings - * - * @since ReduxFramework 0.0.4 - */ - function render() { - - $this->clean(); - - $fieldID = $this->field['id']; - $fieldName = $this->field['name'] . $this->field['name_suffix']; - //$fieldName = $this->parent->args['opt_name'] . '[' . $this->field['id'] . ']'; - - // Set handle number variable. - $twoHandles = false; - if ( 2 == $this->field['handles'] ) { - $twoHandles = true; - } - - // Set default values(s) - if ( true == $twoHandles ) { - $valOne = $this->value[0]; - $valTwo = $this->value[1]; - - $html = 'data-default-one="' . $valOne . '" '; - $html .= 'data-default-two="' . $valTwo . '" '; - - $nameOne = $fieldName . '[1]'; - $nameTwo = $fieldName . '[2]'; - - $idOne = $fieldID . '[1]'; - $idTwo = $fieldID . '[2]'; - } else { - $valOne = $this->value; - $valTwo = ''; - - $html = 'data-default-one="' . $valOne . '"'; - - $nameOne = $fieldName; - $nameTwo = ''; - - $idOne = $fieldID; - $idTwo = ''; - } - - $showInput = false; - $showLabel = false; - $showSelect = false; - - // TEXT output - if ( $this->display_text == $this->field['display_value'] ) { - $showInput = true; - echo ''; - - // LABEL output - } elseif ( $this->display_label == $this->field['display_value'] ) { - $showLabel = true; - - $labelNum = $twoHandles ? '-one' : ''; - - echo '
    -
    '; - - // SELECT output - } elseif ( $this->display_select == $this->field['display_value'] ) { - $showSelect = true; - - if ( isset( $this->field['select2'] ) ) { // if there are any let's pass them to js - $select2_params = json_encode( $this->field['select2'] ); - $select2_params = htmlspecialchars( $select2_params, ENT_QUOTES ); - - echo ''; - } - - - echo ''; - } - - // DIV output - echo - '
    -
    '; - - // Double slider output - if ( true == $twoHandles ) { - - // TEXT - if ( true == $showInput ) { - echo ''; - } - - // LABEL - if ( true == $showLabel ) { - echo '
    -
    '; - } - - // SELECT - if ( true == $showSelect ) { - echo ''; - - } - } - - // NO output (input hidden) - if ( $this->display_none == $this->field['display_value'] || $this->display_label == $this->field['display_value'] ) { - echo ''; - - // double slider hidden output - if ( true == $twoHandles ) { - echo ''; - } - } - } - } -} \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/slider/field_slider.scss b/library/admin/ReduxCore/inc/fields/slider/field_slider.scss deleted file mode 100644 index a5f7a2ba..00000000 --- a/library/admin/ReduxCore/inc/fields/slider/field_slider.scss +++ /dev/null @@ -1,81 +0,0 @@ -.redux-container-slider { - .redux-slider-container { - margin-left: 25px; - margin-right: 25px; - width: 200px; - display: inline-block; - vertical-align: middle; - } - - .redux-slider-input, - .redux-slider-select-one, - .redux-slider-select-two { - width: 100px !important; - text-align: center; - } - - .redux-slider-label { - position: absolute; - margin-left: -5px; - } - - .redux-slider-label-one { - position: absolute; - margin-left: -22px; - } - - .redux-slider-label-two { - position: absolute; - margin-top: -21px; - margin-left: 245px; - } -} - -@media screen and (max-width: 782px) { - .redux-container-slider { - input { - display: inline-block !important; - } - } -} - -// Select Slider -@media screen and (max-width: 570px) { - .redux-container-slider { - text-align: center; - - input, - select, - .redux-slider-label, - .select2-container { - display: block !important; - position: inherit; - margin: 10px auto; - } - - .redux-slider-container { - margin-top: 3px; - width: 80%; - } - } -} - -.wp-customizer { - .redux-container-slider { - .redux-slider-label { - float: left; - position: inherit; - width: 25%; - text-align: center; - margin-left:0; - } - .redux-slider-input, .redux-slider-select-one, .redux-slider-select-two { - width: 25% !important; - } - .redux-slider-container { - width: 70%; - margin-right: 0; - margin-left: 5%; - } - } -} \ No newline at end of file diff --git a/library/admin/ReduxCore/inc/fields/slider/vendor/nouislider/redux.jquery.nouislider.css b/library/admin/ReduxCore/inc/fields/slider/vendor/nouislider/redux.jquery.nouislider.css deleted file mode 100644 index 995bbd10..00000000 --- a/library/admin/ReduxCore/inc/fields/slider/vendor/nouislider/redux.jquery.nouislider.css +++ /dev/null @@ -1,172 +0,0 @@ - -/* Functional styling; - * These styles are required for noUiSlider to function. - * You don't need to change these rules to apply your design. - */ -.noUi-target, -.noUi-target * { --webkit-touch-callout: none; --webkit-user-select: none; --ms-touch-action: none; --ms-user-select: none; --moz-user-select: none; --moz-box-sizing: border-box; - box-sizing: border-box; -} -.noUi-base { - width: 100%; - height: 100%; - position: relative; -} -.noUi-origin { - position: absolute; - right: 0; - top: 0; - left: 0; - bottom: 0; -} -.noUi-handle { - position: relative; - z-index: 1; -} -.noUi-stacking .noUi-handle { -/* This class is applied to the lower origin when - its values is > 50%. */ - z-index: 10; -} -.noUi-stacking + .noUi-origin { -/* Fix stacking order in IE7, which incorrectly - creates a new context for the origins. */ - *z-index: -1; -} -.noUi-state-tap .noUi-origin { --webkit-transition: left 0.3s, top 0.3s; - transition: left 0.3s, top 0.3s; -} -.noUi-state-drag * { - cursor: inherit !important; -} - -/* Slider size and handle placement; - */ -.noUi-horizontal { - height: 18px; -} -.noUi-horizontal .noUi-handle { - width: 34px; - height: 28px; - left: -17px; - top: -6px; -} -.noUi-horizontal.noUi-extended { - padding: 0 15px; -} -.noUi-horizontal.noUi-extended .noUi-origin { - right: -15px; -} -.noUi-vertical { - width: 18px; -} -.noUi-vertical .noUi-handle { - width: 28px; - height: 34px; - left: -6px; - top: -17px; -} -.noUi-vertical.noUi-extended { - padding: 15px 0; -} -.noUi-vertical.noUi-extended .noUi-origin { - bottom: -15px; -} - -/* Styling; - */ -.noUi-background { - background: #FAFAFA; - box-shadow: inset 0 1px 1px #f0f0f0; -} -.noUi-connect { - background: #3FB8AF; - box-shadow: inset 0 0 3px rgba(51,51,51,0.45); --webkit-transition: background 450ms; - transition: background 450ms; -} -.noUi-origin { - border-radius: 2px; -} -.noUi-target { - border-radius: 4px; - border: 1px solid #D3D3D3; - box-shadow: inset 0 1px 1px #F0F0F0, 0 3px 6px -5px #BBB; -} -.noUi-target.noUi-connect { - box-shadow: inset 0 0 3px rgba(51,51,51,0.45), 0 3px 6px -5px #BBB; -} - -/* Handles and cursors; - */ -.noUi-dragable { - cursor: w-resize; -} -.noUi-vertical .noUi-dragable { - cursor: n-resize; -} -.noUi-handle { - border: 1px solid #D9D9D9; - border-radius: 3px; - background: #FFF; - cursor: default; - box-shadow: inset 0 0 1px #FFF, - inset 0 1px 7px #EBEBEB, - 0 3px 6px -3px #BBB; -} -.noUi-active { - box-shadow: inset 0 0 1px #FFF, - inset 0 1px 7px #DDD, - 0 3px 6px -3px #BBB; -} - -/* Handle stripes; - */ -.noUi-handle:before, -.noUi-handle:after { - content: ""; - display: block; - position: absolute; - height: 14px; - width: 1px; - background: #E8E7E6; - left: 14px; - top: 6px; -} -.noUi-handle:after { - left: 17px; -} -.noUi-vertical .noUi-handle:before, -.noUi-vertical .noUi-handle:after { - width: 14px; - height: 1px; - left: 6px; - top: 14px; -} -.noUi-vertical .noUi-handle:after { - top: 17px; -} - -/* Disabled state; - */ -[disabled].noUi-connect, -[disabled] .noUi-connect { - background: #B8B8B8; -} -[disabled] .noUi-handle { - cursor: not-allowed; -} - -/* Blocked state; - */ -.noUi-state-blocked.noUi-connect, -.noUi-state-blocked .noUi-connect { - background: #4FDACF; -} diff --git a/library/admin/ReduxCore/inc/fields/slider/vendor/nouislider/redux.jquery.nouislider.js b/library/admin/ReduxCore/inc/fields/slider/vendor/nouislider/redux.jquery.nouislider.js deleted file mode 100644 index 4c05d20f..00000000 --- a/library/admin/ReduxCore/inc/fields/slider/vendor/nouislider/redux.jquery.nouislider.js +++ /dev/null @@ -1,1420 +0,0 @@ -/*! $.noUiSlider - @version 5.0.0 - @author Leon Gersen https://twitter.com/LeonGersen - @license WTFPL http://www.wtfpl.net/about/ - @documentation http://refreshless.com/nouislider/ -*/ - -// ==ClosureCompiler== -// @externs_url http://refreshless.com/externs/jquery-1.8.js -// @compilation_level ADVANCED_OPTIMIZATIONS -// @warning_level VERBOSE -// ==/ClosureCompiler== - -/*jshint laxcomma: true */ -/*jshint smarttabs: true */ -/*jshint sub: true */ - -/*jslint browser: true */ -/*jslint continue: true */ -/*jslint plusplus: true */ -/*jslint white: true */ -/*jslint sub: true */ - -(function( $ ){ - - 'use strict'; - - if ( $['zepto'] && !$.fn.removeData ) { - throw new ReferenceError('Zepto is loaded without the data module.'); - } - - $.fn['noUiSlider'] = function( options, rebuild ){ - - var - // Cache the document and body selectors; - doc = $(document) - ,body = $('body') - - // Namespace for binding and unbinding slider events; - ,namespace = '.nui' - - // Copy of the current value function; - ,$VAL = $.fn.val - - // Re-usable list of classes; - ,clsList = [ - /* 0 */ 'noUi-base' - /* 1 */ ,'noUi-origin' - /* 2 */ ,'noUi-handle' - /* 3 */ ,'noUi-input' - /* 4 */ ,'noUi-active' - /* 5 */ ,'noUi-state-tap' - /* 6 */ ,'noUi-target' - /* 7 */ ,'-lower' - /* 8 */ ,'-upper' - /* 9 */ ,'noUi-connect' - /* 10 */ ,'noUi-horizontal' - /* 11 */ ,'noUi-vertical' - /* 12 */ ,'noUi-background' - /* 13 */ ,'noUi-stacking' - /* 14 */ ,'noUi-block' - /* 15 */ ,'noUi-state-blocked' - /* 16 */ ,'noUi-ltr' - /* 17 */ ,'noUi-rtl' - /* 18 */ ,'noUi-dragable' - /* 19 */ ,'noUi-extended' - /* 20 */ ,'noUi-state-drag' - ] - - // Determine the events to bind. IE11 implements pointerEvents without - // a prefix, which breaks compatibility with the IE10 implementation. - ,actions = window.navigator['pointerEnabled'] ? { - start: 'pointerdown' - ,move: 'pointermove' - ,end: 'pointerup' - } : window.navigator['msPointerEnabled'] ? { - start: 'MSPointerDown' - ,move: 'MSPointerMove' - ,end: 'MSPointerUp' - } : { - start: 'mousedown touchstart' - ,move: 'mousemove touchmove' - ,end: 'mouseup touchend' - }; - - -// Percentage calculation - - // (percentage) How many percent is this value of this range? - function fromPercentage ( range, value ) { - return (value * 100) / ( range[1] - range[0] ); - } - - // (percentage) Where is this value on this range? - function toPercentage ( range, value ) { - return fromPercentage( range, range[0] < 0 ? - value + Math.abs(range[0]) : - value - range[0] ); - } - - // (value) How much is this percentage on this range? - function isPercentage ( range, value ) { - return ((value * ( range[1] - range[0] )) / 100) + range[0]; - } - - -// Type tests - - // Test in an object is an instance of jQuery or Zepto. - function isInstance ( a ) { - return a instanceof $ || ( $['zepto'] && $['zepto']['isZ'](a) ); - } - - // Checks whether a value is numerical. - function isNumeric ( a ) { - return !isNaN( parseFloat( a ) ) && isFinite( a ); - } - - -// General helper functions - - // Test an array of objects, and calls them if they are a function. - function call ( functions, scope ) { - - // Allow the passing of an unwrapped function. - // Leaves other code a more comprehensible. - if( !$.isArray( functions ) ){ - functions = [ functions ]; - } - - $.each( functions, function(){ - if (typeof this === 'function') { - this.call(scope); - } - }); - } - - // Returns a proxy to set a target using the public value method. - function setN ( target, number ) { - - return function(){ - - // Determine the correct position to set, - // leave the other one unchanged. - var val = [null, null]; - val[ number ] = $(this).val(); - - // Trigger the 'set' callback - target.val(val, true); - }; - } - - // Round a value to the closest 'to'. - function closest ( value, to ){ - return Math.round(value / to) * to; - } - - // Format output value to specified standards. - function format ( value, options ) { - - // Round the value to the resolution that was set - // with the serialization options. - value = value.toFixed( options['decimals'] ); - - // Rounding away decimals might cause a value of -0 - // when using very small ranges. Remove those cases. - if ( parseFloat(value) === 0 ) { - value = value.replace('-0', '0'); - } - - // Apply the proper decimal mark to the value. - return value.replace( '.', options['serialization']['mark'] ); - } - - // Determine the handle closest to an event. - function closestHandle ( handles, location, style ) { - - if ( handles.length === 1 ) { - return handles[0]; - } - - var total = handles[0].offset()[style] + - handles[1].offset()[style]; - - return handles[ location < total / 2 ? 0 : 1 ]; - } - - // Round away small numbers in floating point implementation. - function digits ( value, round ) { - return parseFloat(value.toFixed(round)); - } - -// Event abstraction - - // Provide a clean event with standardized offset values. - function fixEvent ( e ) { - - // Prevent scrolling and panning on touch events, while - // attempting to slide. The tap event also depends on this. - e.preventDefault(); - - // Filter the event to register the type, which can be - // touch, mouse or pointer. Offset changes need to be - // made on an event specific basis. - var touch = e.type.indexOf('touch') === 0 - ,mouse = e.type.indexOf('mouse') === 0 - ,pointer = e.type.indexOf('pointer') === 0 - ,x,y, event = e; - - // IE10 implemented pointer events with a prefix; - if ( e.type.indexOf('MSPointer') === 0 ) { - pointer = true; - } - - // Get the originalEvent, if the event has been wrapped - // by jQuery. Zepto doesn't wrap the event. - if ( e.originalEvent ) { - e = e.originalEvent; - } - - if ( touch ) { - // noUiSlider supports one movement at a time, - // so we can select the first 'changedTouch'. - x = e.changedTouches[0].pageX; - y = e.changedTouches[0].pageY; - } - if ( mouse || pointer ) { - - // Polyfill the pageXOffset and pageYOffset - // variables for IE7 and IE8; - if( !pointer && window.pageXOffset === undefined ){ - window.pageXOffset = document.documentElement.scrollLeft; - window.pageYOffset = document.documentElement.scrollTop; - } - - x = e.clientX + window.pageXOffset; - y = e.clientY + window.pageYOffset; - } - - return $.extend( event, { - 'pointX': x - ,'pointY': y - ,cursor: mouse - }); - } - - // Handler for attaching events trough a proxy - function attach ( events, element, callback, pass ) { - - var target = pass.target; - - // Add the noUiSlider namespace to all events. - events = events.replace( /\s/g, namespace + ' ' ) + namespace; - - // Bind a closure on the target. - return element.on( events, function( e ){ - - // jQuery and Zepto handle unset attributes differently. - var disabled = target.attr('disabled'); - disabled = !( disabled === undefined || disabled === null ); - - // Test if there is anything that should prevent an event - // from being handled, such as a disabled state or an active - // 'tap' transition. - if( target.hasClass('noUi-state-tap') || disabled ) { - return false; - } - - // Call the event handler with three arguments: - // - The event; - // - An object with data for the event; - // - The slider options; - // Having the slider options as a function parameter prevents - // getting it in every function, which muddies things up. - callback ( - fixEvent( e ) - ,pass - ,target.data('base').data('options') - ); - }); - } - - -// Serialization and value storage - - // Store a value on all serialization targets, or get the current value. - function serialize ( a ) { - - /*jshint validthis: true */ - - // Re-scope target for availability within .each; - var target = this.target; - - // Get the value for this handle - if ( a === undefined ) { - return this.element.data('value'); - } - - // Write the value to all serialization objects - // or store a new value on the handle - if ( a === true ) { - a = this.element.data('value'); - } else { - this.element.data('value', a); - } - - // Prevent a serialization call if the value wasn't initialized. - if ( a === undefined ) { - return; - } - - // If the provided element was a function, - // call it with the slider as scope. Otherwise, - // simply call the function on the object. - $.each( this.elements, function() { - if ( typeof this === 'function' ) { - this.call(target, a); - } else { - this[0][this[1]](a); - } - }); - } - - // Map serialization to [ element, method ]. Attach events where required. - function storeElement ( handle, item, number ) { - - // Add a change event to the supplied jQuery objects, - // which triggers the value-setting function on the target. - if ( isInstance( item ) ) { - - var elements = [], target = handle.data('target'); - - // Link the field to the other handle if the - // slider is inverted. - if ( handle.data('options').direction ) { - number = number ? 0 : 1; - } - - // Loop all items so the change event is properly bound, - // and the items can individually be added to the array. - item.each(function(){ - - // Bind the change event. - $(this).on('change' + namespace, setN( target, number )); - - // Store the element with the proper handler. - elements.push([ $(this), 'val' ]); - }); - - return elements; - } - - // Append a new input to the noUiSlider base. - // Prevent the change event from flowing upward. - if ( typeof item === 'string' ) { - - item = [ $('') - .appendTo(handle) - .addClass(clsList[3]) - .change(function ( e ) { - e.stopPropagation(); - }), 'val']; - } - - return [item]; - } - - // Access point and abstraction for serialization. - function store ( handle, i, serialization ) { - - var elements = []; - - // Loops all items in the provided serialization setting, - // add the proper events to them or create new input fields, - // and add them as data to the handle so they can be kept - // in sync with the slider value. - $.each( serialization['to'][i], function( index ){ - elements = elements.concat( - storeElement( handle, serialization['to'][i][index], i ) - ); - }); - - return { - element: handle - ,elements: elements - ,target: handle.data('target') - ,'val': serialize - }; - } - - -// Handle placement - - // Fire callback on unsuccessful handle movement. - function block ( base, stateless ) { - - var target = base.data('target'); - - if ( !target.hasClass(clsList[14]) ){ - - // The visual effects should not always be applied. - if ( !stateless ) { - target.addClass(clsList[15]); - setTimeout(function(){ - target.removeClass(clsList[15]); - }, 450); - } - - target.addClass(clsList[14]); - call( base.data('options').block, target ); - } - } - - // Change inline style and apply proper classes. - function placeHandle ( handle, to ) { - - var settings = handle.data('options'); - - to = digits(to, 7); - - // If the slider can move, remove the class - // indicating the block state. - handle.data('target').removeClass(clsList[14]); - - // Set handle to new location - handle.css( settings['style'], to + '%' ).data('pct', to); - - // Force proper handle stacking - if ( handle.is(':first-child') ) { - handle.toggleClass(clsList[13], to > 50 ); - } - - if ( settings['direction'] ) { - to = 100 - to; - } - - // Write the value to the serialization object. - handle.data('store').val( - format ( isPercentage( settings['range'], to ), settings ) - ); - } - - // Test suggested values and apply margin, step. - function setHandle ( handle, to ) { - - var base = handle.data('base'), settings = base.data('options'), - handles = base.data('handles'), lower = 0, upper = 100; - - // Catch invalid user input - if ( !isNumeric( to ) ){ - return false; - } - - // Handle the step option. - if ( settings['step'] ){ - to = closest( to, settings['step'] ); - } - - if ( handles.length > 1 ){ - if ( handle[0] !== handles[0][0] ) { - lower = digits(handles[0].data('pct')+settings['margin'],7); - } else { - upper = digits(handles[1].data('pct')-settings['margin'],7); - } - } - - // Limit position to boundaries. When the handles aren't set yet, - // they return -1 as a percentage value. - to = Math.min( Math.max( to, lower ), upper < 0 ? 100 : upper ); - - // Stop handling this call if the handle can't move past another. - // Return an array containing the hit limit, so the caller can - // provide feedback. ( block callback ). - if ( to === handle.data('pct') ) { - return [!lower ? false : lower, upper === 100 ? false : upper]; - } - - placeHandle ( handle, to ); - return true; - } - - // Handles movement by tapping - function jump ( base, handle, to, callbacks ) { - - // Flag the slider as it is now in a transitional state. - // Transition takes 300 ms, so re-enable the slider afterwards. - base.addClass(clsList[5]); - setTimeout(function(){ - base.removeClass(clsList[5]); - }, 300); - - // Move the handle to the new position. - setHandle( handle, to ); - - // Trigger the 'slide' and 'set' callbacks, - // pass the target so that it is 'this'. - call( callbacks, base.data('target') ); - - base.data('target').change(); - } - - -// Event handlers - - // Handle movement on document for handle and range drag. - function move ( event, Dt, Op ) { - - // Map event movement to a slider percentage. - var handles = Dt.handles, limits, - proposal = event[ Dt.point ] - Dt.start[ Dt.point ]; - - proposal = ( proposal * 100 ) / Dt.size; - - if ( handles.length === 1 ) { - - // Run handle placement, receive true for success or an - // array with potential limits. - limits = setHandle( handles[0], Dt.positions[0] + proposal ); - - if ( limits !== true ) { - - if ( $.inArray ( handles[0].data('pct'), limits ) >= 0 ){ - block ( Dt.base, !Op['margin'] ); - } - return; - } - - } else { - - // Dragging the range could be implemented by forcing the - // 'move' event on both handles, but this solution proved - // lagging on slower devices, resulting in range errors. The - // slightly ugly solution below is considerably faster, and - // it can't move the handle out of sync. Bypass the standard - // setting method, as other checks are needed. - - var l1, u1, l2, u2; - - // Round the proposal to the step setting. - if ( Op['step'] ) { - proposal = closest( proposal, Op['step'] ); - } - - // Determine the new position, store it twice. Once for - // limiting, once for checking whether placement should occur. - l1 = l2 = Dt.positions[0] + proposal; - u1 = u2 = Dt.positions[1] + proposal; - - // Round the values within a sensible range. - if ( l1 < 0 ) { - u1 += -1 * l1; - l1 = 0; - } else if ( u1 > 100 ) { - l1 -= ( u1 - 100 ); - u1 = 100; - } - - // Don't perform placement if no handles are to be changed. - // Check if the lowest value is set to zero. - if ( l2 < 0 && !l1 && !handles[0].data('pct') ) { - return; - } - // The highest value is limited to 100%. - if ( u1 === 100 && u2 > 100 && handles[1].data('pct') === 100 ){ - return; - } - - placeHandle ( handles[0], l1 ); - placeHandle ( handles[1], u1 ); - } - - // Trigger the 'slide' event, if the handle was moved. - call( Op['slide'], Dt.target ); - } - - // Unbind move events on document, call callbacks. - function end ( event, Dt, Op ) { - - // The handle is no longer active, so remove the class. - if ( Dt.handles.length === 1 ) { - Dt.handles[0].data('grab').removeClass(clsList[4]); - } - - // Remove cursor styles and text-selection events bound to the body. - if ( event.cursor ) { - body.css('cursor', '').off( namespace ); - } - - // Unbind the move and end events, which are added on 'start'. - doc.off( namespace ); - - // Trigger the change event. - Dt.target.removeClass( clsList[14] +' '+ clsList[20]).change(); - - // Trigger the 'end' callback. - call( Op['set'], Dt.target ); - } - - // Bind move events on document. - function start ( event, Dt, Op ) { - - // Mark the handle as 'active' so it can be styled. - if( Dt.handles.length === 1 ) { - Dt.handles[0].data('grab').addClass(clsList[4]); - } - - // A drag should never propagate up to the 'tap' event. - event.stopPropagation(); - - // Attach the move event. - attach ( actions.move, doc, move, { - start: event - ,base: Dt.base - ,target: Dt.target - ,handles: Dt.handles - ,positions: [ Dt.handles[0].data('pct') - ,Dt.handles[ Dt.handles.length - 1 ].data('pct') ] - ,point: Op['orientation'] ? 'pointY' : 'pointX' - ,size: Op['orientation'] ? Dt.base.height() : Dt.base.width() - }); - - // Unbind all movement when the drag ends. - attach ( actions.end, doc, end, { - target: Dt.target - ,handles: Dt.handles - }); - - // Text selection isn't an issue on touch devices, - // so adding additional callbacks isn't required. - if ( event.cursor ) { - - // Prevent the 'I' cursor and extend the range-drag cursor. - body.css('cursor', $(event.target).css('cursor')); - - // Mark the target with a dragging state. - if ( Dt.handles.length > 1 ) { - Dt.target.addClass(clsList[20]); - } - - // Prevent text selection when dragging the handles. - body.on('selectstart' + namespace, function( ){ - return false; - }); - } - } - - // Move closest handle to tapped location. - function tap ( event, Dt, Op ) { - - var base = Dt.base, handle, to, point, size; - - // The tap event shouldn't propagate up to trigger 'edge'. - event.stopPropagation(); - - // Determine the direction of the slider. - if ( Op['orientation'] ) { - point = event['pointY']; - size = base.height(); - } else { - point = event['pointX']; - size = base.width(); - } - - // Find the closest handle and calculate the tapped point. - handle = closestHandle( base.data('handles'), point, Op['style'] ); - to = (( point - base.offset()[ Op['style'] ] ) * 100 ) / size; - - // The set handle to the new position. - jump( base, handle, to, [ Op['slide'], Op['set'] ]); - } - - // Move handle to edges when target gets tapped. - function edge ( event, Dt, Op ) { - - var handles = Dt.base.data('handles'), to, i; - - i = Op['orientation'] ? event['pointY'] : event['pointX']; - i = i < Dt.base.offset()[Op['style']]; - - to = i ? 0 : 100; - i = i ? 0 : handles.length - 1; - - jump ( Dt.base, handles[i], to, [ Op['slide'], Op['set'] ]); - } - -// API - - // Validate and standardize input. - function test ( input, sliders ){ - - /* Every input option is tested and parsed. This'll prevent - endless validation in internal methods. These tests are - structured with an item for every option available. An - option can be marked as required by setting the 'r' flag. - The testing function is provided with three arguments: - - The provided value for the option; - - A reference to the options object; - - The name for the option; - - The testing function returns false when an error is detected, - or true when everything is OK. It can also modify the option - object, to make sure all values can be correctly looped elsewhere. */ - - function values ( a ) { - - if ( a.length !== 2 ){ - return false; - } - - // Convert the array to floats - a = [ parseFloat(a[0]), parseFloat(a[1]) ]; - - // Test if all values are numerical - if( !isNumeric(a[0]) || !isNumeric(a[1]) ){ - return false; - } - - // The lowest value must really be the lowest value. - if( a[1] < a[0] ){ - return false; - } - - return a; - } - - var serialization = { - resolution: function(q,o){ - - // Parse the syntactic sugar that is the serialization - // resolution option to a usable integer. - // Checking for a string '1', since the resolution needs - // to be cast to a string to split in on the period. - switch( q ){ - case 1: - case 0.1: - case 0.01: - case 0.001: - case 0.0001: - case 0.00001: - q = q.toString().split('.'); - o['decimals'] = q[0] === '1' ? 0 : q[1].length; - break; - case undefined: - o['decimals'] = 2; - break; - default: - return false; - } - - return true; - } - ,mark: function(q,o,w){ - - if ( !q ) { - o[w]['mark'] = '.'; - return true; - } - - switch( q ){ - case '.': - case ',': - return true; - default: - return false; - } - } - ,to: function(q,o,w){ - - // Checks whether a variable is a candidate to be a - // valid serialization target. - function ser(r){ - return isInstance ( r ) || - typeof r === 'string' || - typeof r === 'function' || - r === false || - ( isInstance ( r[0] ) && - typeof r[0][r[1]] === 'function' ); - } - - // Flatten the serialization array into a reliable - // set of elements, which can be tested and looped. - function filter ( value ) { - - var items = [[],[]]; - - // If a single value is provided it can be pushed - // immediately. - if ( ser(value) ) { - items[0].push(value); - } else { - - // Otherwise, determine whether this is an - // array of single elements or sets. - $.each(value, function(i, val) { - - // Don't handle an overflow of elements. - if( i > 1 ){ - return; - } - - // Decide if this is a group or not - if( ser(val) ){ - items[i].push(val); - } else { - items[i] = items[i].concat(val); - } - }); - } - - return items; - } - - if ( !q ) { - o[w]['to'] = [[],[]]; - } else { - - var i, j; - - // Flatten the serialization array - q = filter ( q ); - - // Reverse the API for RTL sliders. - if ( o['direction'] && q[1].length ) { - q.reverse(); - } - - // Test all elements in the flattened array. - for ( i = 0; i < o['handles']; i++ ) { - for ( j = 0; j < q[i].length; j++ ) { - - // Return false on invalid input - if( !ser(q[i][j]) ){ - return false; - } - - // Remove 'false' elements, since those - // won't be handled anyway. - if( !q[i][j] ){ - q[i].splice(j, 1); - } - } - } - - // Write the new values back - o[w]['to'] = q; - } - - return true; - } - }, tests = { - /* Handles. - * Has default, can be 1 or 2. - */ - 'handles': { - 'r': true - ,'t': function(q){ - q = parseInt(q, 10); - return ( q === 1 || q === 2 ); - } - } - /* Range. - * Must be an array of two numerical floats, - * which can't be identical. - */ - ,'range': { - 'r': true - ,'t': function(q,o,w){ - - o[w] = values(q); - - // The values can't be identical. - return o[w] && o[w][0] !== o[w][1]; - } - } - /* Start. - * Must be an array of two numerical floats when handles = 2; - * Uses 'range' test. - * When handles = 1, a single float is also allowed. - */ - ,'start': { - 'r': true - ,'t': function(q,o,w){ - if( o['handles'] === 1 ){ - if( $.isArray(q) ){ - q = q[0]; - } - q = parseFloat(q); - o.start = [q]; - return isNumeric(q); - } - - o[w] = values(q); - return !!o[w]; - } - } - /* Connect. - * Must be true or false when handles = 2; - * Can use 'lower' and 'upper' when handles = 1. - */ - ,'connect': { - 'r': true - ,'t': function(q,o,w){ - - if ( q === 'lower' ) { - o[w] = 1; - } else if ( q === 'upper' ) { - o[w] = 2; - } else if ( q === true ) { - o[w] = 3; - } else if ( q === false ) { - o[w] = 0; - } else { - return false; - } - - return true; - } - } - /* Connect. - * Will default to horizontal, not required. - */ - ,'orientation': { - 't': function(q,o,w){ - switch (q){ - case 'horizontal': - o[w] = 0; - break; - case 'vertical': - o[w] = 1; - break; - default: return false; - } - return true; - } - } - /* Margin. - * Must be a float, has a default value. - */ - ,'margin': { - 'r': true - ,'t': function(q,o,w){ - q = parseFloat(q); - o[w] = fromPercentage(o['range'], q); - return isNumeric(q); - } - } - /* Direction. - * Required, can be 'ltr' or 'rtl'. - */ - ,'direction': { - 'r': true - ,'t': function(q,o,w){ - - switch ( q ) { - case 'ltr': o[w] = 0; - break; - case 'rtl': o[w] = 1; - // Invert connection for RTL sliders; - o['connect'] = [0,2,1,3][o['connect']]; - break; - default: - return false; - } - - return true; - } - } - /* Behaviour. - * Required, defines responses to tapping and - * dragging elements. - */ - ,'behaviour': { - 'r': true - ,'t': function(q,o,w){ - - o[w] = { - 'tap': q !== (q = q.replace('tap', '')) - ,'extend': q !== (q = q.replace('extend', '')) - ,'drag': q !== (q = q.replace('drag', '')) - ,'fixed': q !== (q = q.replace('fixed', '')) - }; - - return !q.replace('none','').replace(/\-/g,''); - } - } - /* Serialization. - * Required, but has default. Must be an array - * when using two handles, can be a single value when using - * one handle. 'mark' can be period (.) or comma (,). - */ - ,'serialization': { - 'r': true - ,'t': function(q,o,w){ - - return serialization.to( q['to'], o, w ) && - serialization.resolution( q['resolution'], o ) && - serialization.mark( q['mark'], o, w ); - } - } - /* Slide. - * Not required. Must be a function. - */ - ,'slide': { - 't': function(q){ - return $.isFunction(q); - } - } - /* Set. - * Not required. Must be a function. - * Tested using the 'slide' test. - */ - ,'set': { - 't': function(q){ - return $.isFunction(q); - } - } - /* Block. - * Not required. Must be a function. - * Tested using the 'slide' test. - */ - ,'block': { - 't': function(q){ - return $.isFunction(q); - } - } - /* Step. - * Not required. - */ - ,'step': { - 't': function(q,o,w){ - q = parseFloat(q); - o[w] = fromPercentage ( o['range'], q ); - return isNumeric(q); - } - } - }; - - $.each( tests, function( name, test ){ - - /*jslint devel: true */ - - var value = input[name], isSet = value !== undefined; - - // If the value is required but not set, fail. - if( ( test['r'] && !isSet ) || - // If the test returns false, fail. - ( isSet && !test['t']( value, input, name ) ) ){ - - // For debugging purposes it might be very useful to know - // what option caused the trouble. Since throwing an error - // will prevent further script execution, log the error - // first. Test for console, as it might not be available. - if( console && console.log && console.group ){ - console.group( 'Invalid noUiSlider initialisation:' ); - console.log( 'Option:\t', name ); - console.log( 'Value:\t', value ); - console.log( 'Slider(s):\t', sliders ); - console.groupEnd(); - } - - throw new RangeError('noUiSlider'); - } - }); - } - - // Parse options, add classes, attach events, create HTML. - function create ( options ) { - - /*jshint validthis: true */ - - // Store the original set of options on all targets, - // so they can be re-used and re-tested later. - // Make sure to break the relation with the options, - // which will be changed by the 'test' function. - this.data('options', $.extend(true, {}, options)); - - // Set defaults where applicable; - options = $.extend({ - 'handles': 2 - ,'margin': 0 - ,'connect': false - ,'direction': 'ltr' - ,'behaviour': 'tap' - ,'orientation': 'horizontal' - }, options); - - // Make sure the test for serialization runs. - options['serialization'] = options['serialization'] || {}; - - // Run all options through a testing mechanism to ensure correct - // input. The test function will throw errors, so there is - // no need to capture the result of this call. It should be noted - // that options might get modified to be handled properly. E.g. - // wrapping integers in arrays. - test( options, this ); - - // Pre-define the styles. - options['style'] = options['orientation'] ? 'top' : 'left'; - - return this.each(function(){ - - var target = $(this), i, dragable, handles = [], handle, - base = $('
    ').appendTo(target); - - // Throw an error if the slider was already initialized. - if ( target.data('base') ) { - throw new Error('Slider was already initialized.'); - } - - // Apply classes and data to the target. - target.data('base', base).addClass([ - clsList[6] - ,clsList[16 + options['direction']] - ,clsList[10 + options['orientation']] ].join(' ')); - - for (i = 0; i < options['handles']; i++ ) { - - handle = $('
    ').appendTo(base); - - // Add all default and option-specific classes to the - // origins and handles. - handle.addClass( clsList[1] ); - - handle.children().addClass([ - clsList[2] - ,clsList[2] + clsList[ 7 + options['direction'] + - ( options['direction'] ? -1 * i : i ) ]].join(' ') ); - - // Make sure every handle has access to all variables. - handle.data({ - 'base': base - ,'target': target - ,'options': options - ,'grab': handle.children() - ,'pct': -1 - }).attr('data-style', options['style']); - - // Every handle has a storage point, which takes care - // of triggering the proper serialization callbacks. - handle.data({ - 'store': store(handle, i, options['serialization']) - }); - - // Store handles on the base - handles.push(handle); - } - - // Apply the required connection classes to the elements - // that need them. Some classes are made up for several - // segments listed in the class list, to allow easy - // renaming and provide a minor compression benefit. - switch ( options['connect'] ) { - case 1: target.addClass( clsList[9] ); - handles[0].addClass( clsList[12] ); - break; - case 3: handles[1].addClass( clsList[12] ); - /* falls through */ - case 2: handles[0].addClass( clsList[9] ); - /* falls through */ - case 0: target.addClass(clsList[12]); - break; - } - - // Merge base classes with default, - // and store relevant data on the base element. - base.addClass( clsList[0] ).data({ - 'target': target - ,'options': options - ,'handles': handles - }); - - // Use the public value method to set the start values. - target.val( options['start'] ); - - // Attach the standard drag event to the handles. - if ( !options['behaviour']['fixed'] ) { - for ( i = 0; i < handles.length; i++ ) { - - // These events are only bound to the visual handle - // element, not the 'real' origin element. - attach ( actions.start, handles[i].children(), start, { - base: base - ,target: target - ,handles: [ handles[i] ] - }); - } - } - - // Attach the tap event to the slider base. - if ( options['behaviour']['tap'] ) { - attach ( actions.start, base, tap, { - base: base - ,target: target - }); - } - - // Extend tapping behaviour to target - if ( options['behaviour']['extend'] ) { - - target.addClass( clsList[19] ); - - if ( options['behaviour']['tap'] ) { - attach ( actions.start, target, edge, { - base: base - ,target: target - }); - } - } - - // Make the range dragable. - if ( options['behaviour']['drag'] ){ - - dragable = base.find('.'+clsList[9]).addClass(clsList[18]); - - // When the range is fixed, the entire range can - // be dragged by the handles. The handle in the first - // origin will propagate the start event upward, - // but it needs to be bound manually on the other. - if ( options['behaviour']['fixed'] ) { - dragable = dragable - .add( base.children().not(dragable).data('grab') ); - } - - attach ( actions.start, dragable, start, { - base: base - ,target: target - ,handles: handles - }); - } - }); - } - - // Return value for the slider, relative to 'range'. - function getValue ( ) { - - /*jshint validthis: true */ - - var base = $(this).data('base'), answer = []; - - // Loop the handles, and get the value from the input - // for every handle on its' own. - $.each( base.data('handles'), function(){ - answer.push( $(this).data('store').val() ); - }); - - // If the slider has just one handle, return a single value. - // Otherwise, return an array, which is in reverse order - // if the slider is used RTL. - if ( answer.length === 1 ) { - return answer[0]; - } - - if ( base.data('options').direction ) { - return answer.reverse(); - } - - return answer; - } - - // Set value for the slider, relative to 'range'. - function setValue ( args, set ) { - - /*jshint validthis: true */ - - // If the value is to be set to a number, which is valid - // when using a one-handle slider, wrap it in an array. - if( !$.isArray(args) ){ - args = [args]; - } - - // Setting is handled properly for each slider in the data set. - return this.each(function(){ - - var b = $(this).data('base'), to, i, - handles = Array.prototype.slice.call(b.data('handles'),0), - settings = b.data('options'); - - // If there are multiple handles to be set run the setting - // mechanism twice for the first handle, to make sure it - // can be bounced of the second one properly. - if ( handles.length > 1) { - handles[2] = handles[0]; - } - - // The RTL settings is implemented by reversing the front-end, - // internal mechanisms are the same. - if ( settings['direction'] ) { - args.reverse(); - } - - for ( i = 0; i < handles.length; i++ ){ - - // Calculate a new position for the handle. - to = args[ i%2 ]; - - // The set request might want to ignore this handle. - // Test for 'undefined' too, as a two-handle slider - // can still be set with an integer. - if( to === null || to === undefined ) { - continue; - } - - // Add support for the comma (,) as a decimal symbol. - // Replace it by a period so it is handled properly by - // parseFloat. Omitting this would result in a removal - // of decimals. This way, the developer can also - // input a comma separated string. - if( $.type(to) === 'string' ) { - to = to.replace(',', '.'); - } - - // Calculate the new handle position - to = toPercentage( settings['range'], parseFloat( to ) ); - - // Invert the value if this is an right-to-left slider. - if ( settings['direction'] ) { - to = 100 - to; - } - - // If the value of the input doesn't match the slider, - // reset it. Sometimes the input is changed to a value the - // slider has rejected. This can occur when using 'select' - // or 'input[type="number"]' elements. In this case, set - // the value back to the input. - if ( setHandle( handles[i], to ) !== true ){ - handles[i].data('store').val( true ); - } - - // Optionally trigger the 'set' event. - if( set === true ) { - call( settings['set'], $(this) ); - } - } - }); - } - - // Unbind all attached events, remove classed and HTML. - function destroy ( target ) { - - // Start the list of elements to be unbound with the target. - var elements = [[target,'']]; - - // Get the fields bound to both handles. - $.each(target.data('base').data('handles'), function(){ - elements = elements.concat( $(this).data('store').elements ); - }); - - // Remove all events added by noUiSlider. - $.each(elements, function(){ - if( this.length > 1 ){ - this[0].off( namespace ); - } - }); - - // Remove all classes from the target. - target.removeClass(clsList.join(' ')); - - // Empty the target and remove all data. - target.empty().removeData('base options'); - } - - // Merge options with current initialization, destroy slider - // and reinitialize. - function build ( options ) { - - /*jshint validthis: true */ - - return this.each(function(){ - - // When uninitialised, jQuery will return '', - // Zepto returns undefined. Both are falsy. - var values = $(this).val() || false, - current = $(this).data('options'), - // Extend the current setup with the new options. - setup = $.extend( {}, current, options ); - - // If there was a slider initialised, remove it first. - if ( values !== false ) { - destroy( $(this) ); - } - - // Make the destroy method publicly accessible. - if( !options ) { - return; - } - - // Create a new slider - $(this)['noUiSlider']( setup ); - - // Set the slider values back. If the start options changed, - // it gets precedence. - if ( values !== false && setup.start === current.start ) { - $(this).val( values ); - } - }); - } - - // Overwrite the native jQuery value function - // with a simple handler. noUiSlider will use the internal - // value method, anything else will use the standard method. - $.fn.val = function(){ - - // If the function is called without arguments, - // act as a 'getter'. Call the getValue function - // in the same scope as this call. - if ( this.hasClass( clsList[6] ) ){ - return arguments.length ? - setValue.apply( this, arguments ) : - getValue.apply( this ); - } - - // If this isn't noUiSlider, continue with jQuery's - // original method. - return $VAL.apply( this, arguments ); - }; - - return ( rebuild ? build : create ).call( this, options ); - }; - -}( window['jQuery'] || window['Zepto'] )); diff --git a/library/admin/ReduxCore/inc/fields/slider/vendor/nouislider/redux.jquery.nouislider.min.js b/library/admin/ReduxCore/inc/fields/slider/vendor/nouislider/redux.jquery.nouislider.min.js deleted file mode 100644 index 73dfa3ce..00000000 --- a/library/admin/ReduxCore/inc/fields/slider/vendor/nouislider/redux.jquery.nouislider.min.js +++ /dev/null @@ -1,20 +0,0 @@ -(function(f){if(f.zepto&&!f.fn.removeData)throw new ReferenceError("Zepto is loaded without the data module.");f.fn.noUiSlider=function(C,D){function s(a,b){return 100*b/(a[1]-a[0])}function E(a,b){return b*(a[1]-a[0])/100+a[0]}function t(a){return a instanceof f||f.zepto&&f.zepto.isZ(a)}function n(a){return!isNaN(parseFloat(a))&&isFinite(a)}function r(a,b){f.isArray(a)||(a=[a]);f.each(a,function(){"function"===typeof this&&this.call(b)})}function F(a,b){return function(){var c=[null,null];c[b]=f(this).val(); -a.val(c,!0)}}function G(a,b){a=a.toFixed(b.decimals);0===parseFloat(a)&&(a=a.replace("-0","0"));return a.replace(".",b.serialization.mark)}function u(a){return parseFloat(a.toFixed(7))}function p(a,b,c,d){var e=d.target;a=a.replace(/\s/g,h+" ")+h;b.on(a,function(a){var b=e.attr("disabled");if(e.hasClass("noUi-state-tap")||void 0!==b&&null!==b)return!1;var g;a.preventDefault();var b=0===a.type.indexOf("touch"),h=0===a.type.indexOf("mouse"),l=0===a.type.indexOf("pointer"),v,H=a;0===a.type.indexOf("MSPointer")&& -(l=!0);a.originalEvent&&(a=a.originalEvent);b&&(g=a.changedTouches[0].pageX,v=a.changedTouches[0].pageY);if(h||l)l||void 0!==window.pageXOffset||(window.pageXOffset=document.documentElement.scrollLeft,window.pageYOffset=document.documentElement.scrollTop),g=a.clientX+window.pageXOffset,v=a.clientY+window.pageYOffset;g=f.extend(H,{pointX:g,pointY:v,cursor:h});c(g,d,e.data("base").data("options"))})}function I(a){var b=this.target;if(void 0===a)return this.element.data("value");!0===a?a=this.element.data("value"): -this.element.data("value",a);void 0!==a&&f.each(this.elements,function(){if("function"===typeof this)this.call(b,a);else this[0][this[1]](a)})}function J(a,b,c){if(t(b)){var d=[],e=a.data("target");a.data("options").direction&&(c=c?0:1);b.each(function(){f(this).on("change"+h,F(e,c));d.push([f(this),"val"])});return d}"string"===typeof b&&(b=[f('').appendTo(a).addClass(g[3]).change(function(a){a.stopPropagation()}),"val"]);return[b]}function K(a,b,c){var d=[];f.each(c.to[b], -function(e){d=d.concat(J(a,c.to[b][e],b))});return{element:a,elements:d,target:a.data("target"),val:I}}function L(a,b){var c=a.data("target");c.hasClass(g[14])||(b||(c.addClass(g[15]),setTimeout(function(){c.removeClass(g[15])},450)),c.addClass(g[14]),r(a.data("options").h,c))}function w(a,b){var c=a.data("options");b=u(b);a.data("target").removeClass(g[14]);a.css(c.style,b+"%").data("pct",b);a.is(":first-child")&&a.toggleClass(g[13],50k?100:k);if(b===a.data("pct"))return[e?e:!1,100===k?!1:k];w(a,b);return!0}function A(a,b,c,d){a.addClass(g[5]);setTimeout(function(){a.removeClass(g[5])},300);x(b,c);r(d,a.data("target"));a.data("target").change()}function M(a,b,c){var d= -b.a,e=a[b.d]-b.start[b.d],e=100*e/b.size;if(1===d.length){if(a=x(d[0],b.c[0]+e),!0!==a){0<=f.inArray(d[0].data("pct"),a)&&L(b.b,!c.margin);return}}else{var k,m;c.step&&(a=c.step,e=Math.round(e/a)*a);a=k=b.c[0]+e;e=m=b.c[1]+e;0>a?(e+=-1*a,a=0):100k&&!a&&!d[0].data("pct")||100===e&&100").appendTo(b);if(b.data("base"))throw Error("Slider was already initialized.");b.data("base",k).addClass([g[6],g[16+a.direction],g[10+a.orientation]].join(" "));for(c=0;c
    ").appendTo(k),e.addClass(g[1]),e.children().addClass([g[2], -g[2]+g[7+a.direction+(a.direction?-1*c:c)]].join(" ")),e.data({base:k,target:b,options:a,grab:e.children(),pct:-1}).attr("data-style",a.style),e.data({store:K(e,c,a.serialization)}),d.push(e);switch(a.connect){case 1:b.addClass(g[9]);d[0].addClass(g[12]);break;case 3:d[1].addClass(g[12]);case 2:d[0].addClass(g[9]);case 0:b.addClass(g[12])}k.addClass(g[0]).data({target:b,options:a,handles:d});b.val(a.start);if(!a.behaviour.fixed)for(c=0;ch[0]?d+Math.abs(h[0]):d-h[0]);g.direction&&(d=100-d);!0!==x(e[c],d)&&e[c].data("store").val(!0);!0===b&&r(g.set,f(this))}})}function U(a){var b=[[a,""]];f.each(a.data("base").data("handles"), -function(){b=b.concat(f(this).data("store").elements)});f.each(b,function(){1
    '; - - require_once 'views/about.php'; - - } - - /** - * Render Changelog Screen - * - * @access public - * @since 2.0.3 - * @return void - */ - public function changelog_screen() { - // Stupid hack for Wordpress alerts and warnings - echo '

    '; - - require_once 'views/changelog.php'; - - } - - /** - * Render Changelog Screen - * - * @access public - * @since 2.0.3 - * @return void - */ - public function redux_extensions() { - // Stupid hack for Wordpress alerts and warnings - echo '

    '; - - require_once 'views/extensions.php'; - - } - - - /** - * Render Get Support Screen - * - * @access public - * @since 1.9 - * @return void - */ - public function get_support() { - // Stupid hack for Wordpress alerts and warnings - echo '

    '; - - require_once 'views/support.php'; - - } - - /** - * Render Credits Screen - * - * @access public - * @since 1.4 - * @return void - */ - public function credits_screen() { - // Stupid hack for Wordpress alerts and warnings - echo '

    '; - - require_once 'views/credits.php'; - - } - - /** - * Render Status Report Screen - * - * @access public - * @since 1.4 - * @return void - */ - public function status_screen() { - // Stupid hack for Wordpress alerts and warnings - echo '

    '; - - require_once 'views/status_report.php'; - - } - - /** - * Parse the Redux readme.txt file - * - * @since 2.0.3 - * @return string $readme HTML formatted readme file - */ - public function parse_readme() { - if ( file_exists( ReduxFramework::$_dir . 'inc/fields/raw/parsedown.php' ) ) { - require_once ReduxFramework::$_dir . 'inc/fields/raw/parsedown.php'; - $Parsedown = new Parsedown(); - - return $Parsedown->text( trim( str_replace( '# Redux Framework Changelog', '', wp_remote_retrieve_body( wp_remote_get( ReduxFramework::$_url . '../CHANGELOG.md' ) ) ) ) ); - } - - return ''; - - } - - public function actions() { - ?> -

    - Docs - Review Us - Donate - - -

    - get_contributors(); - - if ( empty ( $contributors ) ) { - return ''; - } - - $contributor_list = ''; - - return $contributor_list; - } - - /** - * Retreive list of contributors from GitHub. - * - * @access public - * @since 1.4 - * @return array $contributors List of contributors - */ - public function get_contributors() { - $contributors = get_transient( 'redux_contributors' ); - - if ( false !== $contributors ) { - return $contributors; - } - - $response = wp_remote_get( 'https://api.github.com/repos/ReduxFramework/redux-framework/contributors', array( 'sslverify' => false ) ); - - if ( is_wp_error( $response ) || 200 != wp_remote_retrieve_response_code( $response ) ) { - return array(); - } - - $contributors = json_decode( wp_remote_retrieve_body( $response ) ); - - if ( ! is_array( $contributors ) ) { - return array(); - } - - set_transient( 'redux_contributors', $contributors, 3600 ); - - return $contributors; - } - } - - new Redux_Welcome(); - diff --git a/library/admin/ReduxCore/languages/README.txt b/library/admin/ReduxCore/languages/README.txt deleted file mode 100644 index 57b2f194..00000000 --- a/library/admin/ReduxCore/languages/README.txt +++ /dev/null @@ -1 +0,0 @@ -Please visit: https://github.com/ReduxFramework/ReduxFramework/wiki/Translate for details on how you can help. diff --git a/library/admin/ReduxCore/languages/ar.mo b/library/admin/ReduxCore/languages/ar.mo deleted file mode 100644 index e682d0a5..00000000 Binary files a/library/admin/ReduxCore/languages/ar.mo and /dev/null differ diff --git a/library/admin/ReduxCore/languages/bg_BG.mo b/library/admin/ReduxCore/languages/bg_BG.mo deleted file mode 100644 index c411c135..00000000 Binary files a/library/admin/ReduxCore/languages/bg_BG.mo and /dev/null differ diff --git a/library/admin/ReduxCore/languages/bn_BD.mo b/library/admin/ReduxCore/languages/bn_BD.mo deleted file mode 100644 index f944e029..00000000 Binary files a/library/admin/ReduxCore/languages/bn_BD.mo and /dev/null differ diff --git a/library/admin/ReduxCore/languages/cs_CZ.mo b/library/admin/ReduxCore/languages/cs_CZ.mo deleted file mode 100644 index c35eb11d..00000000 Binary files a/library/admin/ReduxCore/languages/cs_CZ.mo and /dev/null differ diff --git a/library/admin/ReduxCore/languages/da_DK.mo b/library/admin/ReduxCore/languages/da_DK.mo deleted file mode 100644 index d78efa9c..00000000 Binary files a/library/admin/ReduxCore/languages/da_DK.mo and /dev/null differ diff --git a/library/admin/ReduxCore/languages/de_DE.mo b/library/admin/ReduxCore/languages/de_DE.mo deleted file mode 100644 index 939e617e..00000000 Binary files a/library/admin/ReduxCore/languages/de_DE.mo and /dev/null differ diff --git a/library/admin/ReduxCore/languages/el.mo b/library/admin/ReduxCore/languages/el.mo deleted file mode 100644 index 96879d12..00000000 Binary files a/library/admin/ReduxCore/languages/el.mo and /dev/null differ diff --git a/library/admin/ReduxCore/languages/es_ES.mo b/library/admin/ReduxCore/languages/es_ES.mo deleted file mode 100644 index 2b9b075a..00000000 Binary files a/library/admin/ReduxCore/languages/es_ES.mo and /dev/null differ diff --git a/library/admin/ReduxCore/languages/es_MX.mo b/library/admin/ReduxCore/languages/es_MX.mo deleted file mode 100644 index 906a2ad3..00000000 Binary files a/library/admin/ReduxCore/languages/es_MX.mo and /dev/null differ diff --git a/library/admin/ReduxCore/languages/fa_IR.mo b/library/admin/ReduxCore/languages/fa_IR.mo deleted file mode 100644 index 4e23d001..00000000 Binary files a/library/admin/ReduxCore/languages/fa_IR.mo and /dev/null differ diff --git a/library/admin/ReduxCore/languages/fi.mo b/library/admin/ReduxCore/languages/fi.mo deleted file mode 100644 index d04d4cc7..00000000 Binary files a/library/admin/ReduxCore/languages/fi.mo and /dev/null differ diff --git a/library/admin/ReduxCore/languages/fr_FR.mo b/library/admin/ReduxCore/languages/fr_FR.mo deleted file mode 100644 index 9c960e1c..00000000 Binary files a/library/admin/ReduxCore/languages/fr_FR.mo and /dev/null differ diff --git a/library/admin/ReduxCore/languages/he_IL.mo b/library/admin/ReduxCore/languages/he_IL.mo deleted file mode 100644 index 88356c80..00000000 Binary files a/library/admin/ReduxCore/languages/he_IL.mo and /dev/null differ diff --git a/library/admin/ReduxCore/languages/hi_IN.mo b/library/admin/ReduxCore/languages/hi_IN.mo deleted file mode 100644 index 3dc6c819..00000000 Binary files a/library/admin/ReduxCore/languages/hi_IN.mo and /dev/null differ diff --git a/library/admin/ReduxCore/languages/hr.mo b/library/admin/ReduxCore/languages/hr.mo deleted file mode 100644 index 55ce5ff4..00000000 Binary files a/library/admin/ReduxCore/languages/hr.mo and /dev/null differ diff --git a/library/admin/ReduxCore/languages/hu_HU.mo b/library/admin/ReduxCore/languages/hu_HU.mo deleted file mode 100644 index ba74bb8a..00000000 Binary files a/library/admin/ReduxCore/languages/hu_HU.mo and /dev/null differ diff --git a/library/admin/ReduxCore/languages/id_ID.mo b/library/admin/ReduxCore/languages/id_ID.mo deleted file mode 100644 index 6d6af7d6..00000000 Binary files a/library/admin/ReduxCore/languages/id_ID.mo and /dev/null differ diff --git a/library/admin/ReduxCore/languages/it_IT.mo b/library/admin/ReduxCore/languages/it_IT.mo deleted file mode 100644 index 9e89ac3a..00000000 Binary files a/library/admin/ReduxCore/languages/it_IT.mo and /dev/null differ diff --git a/library/admin/ReduxCore/languages/ja.mo b/library/admin/ReduxCore/languages/ja.mo deleted file mode 100644 index ac03f4b3..00000000 Binary files a/library/admin/ReduxCore/languages/ja.mo and /dev/null differ diff --git a/library/admin/ReduxCore/languages/km.mo b/library/admin/ReduxCore/languages/km.mo deleted file mode 100644 index cffc6129..00000000 Binary files a/library/admin/ReduxCore/languages/km.mo and /dev/null differ diff --git a/library/admin/ReduxCore/languages/lt_LT.mo b/library/admin/ReduxCore/languages/lt_LT.mo deleted file mode 100644 index e69de29b..00000000 diff --git a/library/admin/ReduxCore/languages/nb_NO.mo b/library/admin/ReduxCore/languages/nb_NO.mo deleted file mode 100644 index 4ceb866b..00000000 Binary files a/library/admin/ReduxCore/languages/nb_NO.mo and /dev/null differ diff --git a/library/admin/ReduxCore/languages/ne_NP.mo b/library/admin/ReduxCore/languages/ne_NP.mo deleted file mode 100644 index 274e193b..00000000 Binary files a/library/admin/ReduxCore/languages/ne_NP.mo and /dev/null differ diff --git a/library/admin/ReduxCore/languages/nl_NL.mo b/library/admin/ReduxCore/languages/nl_NL.mo deleted file mode 100644 index 01f63234..00000000 Binary files a/library/admin/ReduxCore/languages/nl_NL.mo and /dev/null differ diff --git a/library/admin/ReduxCore/languages/pl_PL.mo b/library/admin/ReduxCore/languages/pl_PL.mo deleted file mode 100644 index 513a32d3..00000000 Binary files a/library/admin/ReduxCore/languages/pl_PL.mo and /dev/null differ diff --git a/library/admin/ReduxCore/languages/pt_BR.mo b/library/admin/ReduxCore/languages/pt_BR.mo deleted file mode 100644 index 192cd35c..00000000 Binary files a/library/admin/ReduxCore/languages/pt_BR.mo and /dev/null differ diff --git a/library/admin/ReduxCore/languages/pt_PT.mo b/library/admin/ReduxCore/languages/pt_PT.mo deleted file mode 100644 index 7448f949..00000000 Binary files a/library/admin/ReduxCore/languages/pt_PT.mo and /dev/null differ diff --git a/library/admin/ReduxCore/languages/redux-framework.pot b/library/admin/ReduxCore/languages/redux-framework.pot deleted file mode 100644 index 93d09c31..00000000 --- a/library/admin/ReduxCore/languages/redux-framework.pot +++ /dev/null @@ -1,1556 +0,0 @@ -# Copyright (C) 2015 Team Redux -# This file is distributed under the GPL3+. -msgid "" -msgstr "" -"Project-Id-Version: Redux Framework 3.5.3\n" -"Report-Msgid-Bugs-To: " -"https://github.com/ReduxFramework/ReduxFramework/issues\n" -"POT-Creation-Date: 2015-04-15 23:15:00+00:00\n" -"MIME-Version: 1.0\n" -"Content-Type: text/plain; charset=utf-8\n" -"Content-Transfer-Encoding: 8bit\n" -"PO-Revision-Date: 2015-MO-DA HO:MI+ZONE\n" -"Last-Translator: FULL NAME \n" -"Language-Team: LANGUAGE \n" -"X-Generator: grunt-wp-i18n 0.4.9\n" -"X-Poedit-KeywordsList: " -"__;_e;_x:1,2c;_ex:1,2c;_n:1,2;_nx:1,2,4c;_n_noop:1,2;_nx_noop:1,2,3c;esc_" -"attr__;esc_html__;esc_attr_e;esc_html_e;esc_attr_x:1,2c;esc_html_x:1,2c;\n" -"Language: en\n" -"Plural-Forms: nplurals=2; plural=(n != 1);\n" -"X-Poedit-Country: United States\n" -"X-Poedit-SourceCharset: UTF-8\n" -"X-Poedit-Basepath: ../\n" -"X-Poedit-SearchPath-0: .\n" -"X-Poedit-Bookmarks: \n" -"X-Textdomain-Support: yes\n" - -#: ReduxCore/core/enqueue.php:397 -#: ReduxCore/inc/extensions/customizer/extension_customizer.php:566 -msgid "You have changes that are not saved. Would you like to save them now?" -msgstr "" - -#: ReduxCore/core/enqueue.php:405 -#: ReduxCore/inc/extensions/customizer/extension_customizer.php:567 -msgid "Are you sure? Resetting will lose all custom values." -msgstr "" - -#: ReduxCore/core/enqueue.php:413 -msgid "Are you sure? Resetting will lose all custom values in this section." -msgstr "" - -#: ReduxCore/core/enqueue.php:421 -#: ReduxCore/inc/extensions/customizer/extension_customizer.php:568 -msgid "" -"Your current options will be replaced with the values of this preset. Would " -"you like to proceed?" -msgstr "" - -#: ReduxCore/core/enqueue.php:428 -msgid "Please Wait" -msgstr "" - -#: ReduxCore/core/enqueue.php:439 -msgid "There was an error saving. Here is the result of your action:" -msgstr "" - -#: ReduxCore/core/enqueue.php:440 -msgid "There was a problem with your action. Please try again or reload the page." -msgstr "" - -#: ReduxCore/core/panel.php:65 -msgid "Warning- This options panel will not work properly without javascript!" -msgstr "" - -#: ReduxCore/core/panel.php:141 -msgid "Settings Imported!" -msgstr "" - -#: ReduxCore/core/panel.php:156 -msgid "All Defaults Restored!" -msgstr "" - -#: ReduxCore/core/panel.php:170 -msgid "Section Defaults Restored!" -msgstr "" - -#: ReduxCore/core/panel.php:184 -msgid "Settings Saved!" -msgstr "" - -#: ReduxCore/core/panel.php:204 -msgid "Settings have changed, you should save them!" -msgstr "" - -#: ReduxCore/core/panel.php:212 -msgid "error(s) were found!" -msgstr "" - -#: ReduxCore/core/panel.php:220 -msgid "warning(s) were found!" -msgstr "" - -#: ReduxCore/core/panel.php:340 -msgid "" -"Your panel has bundled outdated copies of Redux Framework template " -"files – if you encounter functionality issues this could be " -"the reason. Ensure you update or remove them." -msgstr "" - -#: ReduxCore/framework.php:220 -msgid "Options panel created using %1$s" -msgstr "" - -#. Plugin Name of the plugin/theme -msgid "Redux Framework" -msgstr "" - -#: ReduxCore/framework.php:224 ReduxCore/framework.php:228 -msgid "Options" -msgstr "" - -#: ReduxCore/framework.php:1389 -#: ReduxCore/templates/panel/menu_container.tpl.php:63 -msgid "System Info" -msgstr "" - -#: ReduxCore/framework.php:1692 -msgid "Enable" -msgstr "" - -#: ReduxCore/framework.php:1697 -msgid "Disable" -msgstr "" - -#: ReduxCore/framework.php:1703 -msgid "moving the mouse over" -msgstr "" - -#: ReduxCore/framework.php:1705 -msgid "clicking" -msgstr "" - -#: ReduxCore/framework.php:1709 -msgid "" -"Hints are tooltips that popup when %d the hint icon, offering addition " -"information about the field in which they appear. They can be %d d by " -"using the link below." -msgstr "" - -#: ReduxCore/framework.php:1714 -msgid "Hints" -msgstr "" - -#: ReduxCore/framework.php:1841 -msgid "Default" -msgstr "" - -#: ReduxCore/framework.php:2680 -msgid "Invalid security credential, please reload the page and try again." -msgstr "" - -#: ReduxCore/framework.php:2766 -msgid "Your panel has no fields. Nothing to save." -msgstr "" - -#: ReduxCore/inc/class.redux_filesystem.php:23 -msgid "Unable to modify required files. Please ensure that" -msgstr "" - -#: ReduxCore/inc/class.redux_filesystem.php:25 -msgid "has the proper read/write permissions or enter your FTP information below." -msgstr "" - -#: ReduxCore/inc/class.redux_functions.php:237 -msgid "Dismiss" -msgstr "" - -#: ReduxCore/inc/class.redux_helpers.php:589 -msgid "" -"%s version %s is out of " -"date. The core version is %s" -msgstr "" - -#: ReduxCore/inc/class.redux_themecheck.php:61 -msgid "" -"The theme you are testing has %s embedded. We invite you to read the " -"%sTheme-Check Documentation%s to understand some warnings you will see " -"because of Redux." -msgstr "" - -#: ReduxCore/inc/class.redux_themecheck.php:109 -msgid "" -"The following directories & files are still located in your " -"Redux directory. They may cause errors in Theme-Check." -msgstr "" - -#: ReduxCore/inc/debug.php:41 ReduxCore/inc/debug.php:69 -#: ReduxCore/inc/debug.php:76 ReduxCore/inc/debug.php:77 -msgid "Options Object" -msgstr "" - -#: ReduxCore/inc/debug.php:54 -msgid "Show Object in Javascript Console Object" -msgstr "" - -#: ReduxCore/inc/extensions/customizer/extension_customizer.php:601 -msgid "You have changes that are not saved. Would you like to save them now?" -msgstr "" - -#: ReduxCore/inc/extensions/customizer/extension_customizer.php:602 -msgid "Are you sure? Resetting will lose all custom values." -msgstr "" - -#: ReduxCore/inc/extensions/customizer/extension_customizer.php:603 -msgid "" -"Your current options will be replaced with the values of this preset. " -"Would you like to proceed?" -msgstr "" - -#: ReduxCore/inc/extensions/import_export/extension_import_export.php:120 -msgid "Import / Export" -msgstr "" - -#: ReduxCore/inc/extensions/import_export/import_export/field_import_export.php:103 -msgid "Import Options" -msgstr "" - -#: ReduxCore/inc/extensions/import_export/import_export/field_import_export.php:104 -msgid "Import from File" -msgstr "" - -#: ReduxCore/inc/extensions/import_export/import_export/field_import_export.php:104 -msgid "Import from URL" -msgstr "" - -#: ReduxCore/inc/extensions/import_export/import_export/field_import_export.php:107 -msgid "" -"Input your backup file below and hit Import to restore your sites options " -"from a backup." -msgstr "" - -#: ReduxCore/inc/extensions/import_export/import_export/field_import_export.php:112 -msgid "" -"Input the URL to another sites options set and hit Import to load the " -"options from that site." -msgstr "" - -#: ReduxCore/inc/extensions/import_export/import_export/field_import_export.php:116 -msgid "Import" -msgstr "" - -#: ReduxCore/inc/extensions/import_export/import_export/field_import_export.php:116 -msgid "" -"WARNING! This will overwrite all existing option values, please proceed " -"with caution!" -msgstr "" - -#: ReduxCore/inc/extensions/import_export/import_export/field_import_export.php:119 -msgid "Export Options" -msgstr "" - -#: ReduxCore/inc/extensions/import_export/import_export/field_import_export.php:121 -msgid "" -"Here you can copy/download your current option settings. Keep this safe as " -"you can use it as a backup should anything go wrong, or you can use it to " -"restore your settings on this site (or any other site)." -msgstr "" - -#: ReduxCore/inc/extensions/import_export/import_export/field_import_export.php:126 -msgid "Copy Data" -msgstr "" - -#: ReduxCore/inc/extensions/import_export/import_export/field_import_export.php:126 -msgid "Download Data File" -msgstr "" - -#: ReduxCore/inc/extensions/import_export/import_export/field_import_export.php:126 -msgid "Copy Export URL" -msgstr "" - -#: ReduxCore/inc/fields/background/field_background.php:124 -#: ReduxCore/inc/fields/color/field_color.php:73 -#: ReduxCore/inc/fields/color_gradient/field_color_gradient.php:79 -#: ReduxCore/inc/fields/color_gradient/field_color_gradient.php:91 -msgid "Transparent" -msgstr "" - -#: ReduxCore/inc/fields/background/field_background.php:141 -msgid "Background Repeat" -msgstr "" - -#: ReduxCore/inc/fields/background/field_background.php:157 -msgid "Background Clip" -msgstr "" - -#: ReduxCore/inc/fields/background/field_background.php:173 -msgid "Background Origin" -msgstr "" - -#: ReduxCore/inc/fields/background/field_background.php:188 -msgid "Background Size" -msgstr "" - -#: ReduxCore/inc/fields/background/field_background.php:203 -msgid "Background Attachment" -msgstr "" - -#: ReduxCore/inc/fields/background/field_background.php:223 -msgid "Background Position" -msgstr "" - -#: ReduxCore/inc/fields/background/field_background.php:277 -#: ReduxCore/inc/fields/media/field_media.php:149 -msgid "No media selected" -msgstr "" - -#: ReduxCore/inc/fields/background/field_background.php:314 -#: ReduxCore/inc/fields/media/field_media.php:198 -#: ReduxCore/inc/fields/slides/field_slides.php:126 -#: ReduxCore/inc/fields/slides/field_slides.php:188 -msgid "Upload" -msgstr "" - -#: ReduxCore/inc/fields/background/field_background.php:321 -#: ReduxCore/inc/fields/media/field_media.php:205 -#: ReduxCore/inc/fields/multi_text/field_multi_text.php:69 -#: ReduxCore/inc/fields/multi_text/field_multi_text.php:73 -#: ReduxCore/inc/fields/multi_text/field_multi_text.php:76 -#: ReduxCore/inc/fields/slides/field_slides.php:133 -#: ReduxCore/inc/fields/slides/field_slides.php:190 -msgid "Remove" -msgstr "" - -#: ReduxCore/inc/fields/border/field_border.php:125 -#: ReduxCore/inc/fields/spacing/field_spacing.php:191 -msgid "All" -msgstr "" - -#: ReduxCore/inc/fields/border/field_border.php:138 -#: ReduxCore/inc/fields/spacing/field_spacing.php:215 -msgid "Top" -msgstr "" - -#: ReduxCore/inc/fields/border/field_border.php:145 -#: ReduxCore/inc/fields/spacing/field_spacing.php:222 -msgid "Right" -msgstr "" - -#: ReduxCore/inc/fields/border/field_border.php:152 -#: ReduxCore/inc/fields/spacing/field_spacing.php:229 -msgid "Bottom" -msgstr "" - -#: ReduxCore/inc/fields/border/field_border.php:159 -#: ReduxCore/inc/fields/spacing/field_spacing.php:236 -msgid "Left" -msgstr "" - -#: ReduxCore/inc/fields/border/field_border.php:173 -msgid "Border style" -msgstr "" - -#: ReduxCore/inc/fields/color_gradient/field_color_gradient.php:68 -msgid "From " -msgstr "" - -#: ReduxCore/inc/fields/color_gradient/field_color_gradient.php:82 -msgid "To " -msgstr "" - -#: ReduxCore/inc/fields/dimensions/field_dimensions.php:162 -msgid "Width" -msgstr "" - -#: ReduxCore/inc/fields/dimensions/field_dimensions.php:178 -#: ReduxCore/inc/fields/typography/field_typography.php:442 -msgid "Height" -msgstr "" - -#: ReduxCore/inc/fields/dimensions/field_dimensions.php:189 -#: ReduxCore/inc/fields/dimensions/field_dimensions.php:190 -#: ReduxCore/inc/fields/spacing/field_spacing.php:245 -#: ReduxCore/inc/fields/spacing/field_spacing.php:246 -msgid "Units" -msgstr "" - -#: ReduxCore/inc/fields/gallery/field_gallery.php:73 -msgid "Add/Edit Gallery" -msgstr "" - -#: ReduxCore/inc/fields/gallery/field_gallery.php:74 -msgid "Clear Gallery" -msgstr "" - -#: ReduxCore/inc/fields/link_color/field_link_color.php:87 -msgid "Regular" -msgstr "" - -#: ReduxCore/inc/fields/link_color/field_link_color.php:91 -msgid "Hover" -msgstr "" - -#: ReduxCore/inc/fields/link_color/field_link_color.php:95 -msgid "Visited" -msgstr "" - -#: ReduxCore/inc/fields/link_color/field_link_color.php:99 -msgid "Active" -msgstr "" - -#: ReduxCore/inc/fields/multi_text/field_multi_text.php:61 -msgid "Add More" -msgstr "" - -#: ReduxCore/inc/fields/password/field_password.php:62 -msgid "Password" -msgstr "" - -#: ReduxCore/inc/fields/password/field_password.php:63 -msgid "Username" -msgstr "" - -#: ReduxCore/inc/fields/select/field_select.php:83 -#: ReduxCore/inc/fields/select_image/field_select_image.php:63 -msgid "Select an item" -msgstr "" - -#: ReduxCore/inc/fields/select/field_select.php:134 -#: ReduxCore/inc/fields/select_image/field_select_image.php:144 -msgid "No items of this type were found." -msgstr "" - -#: ReduxCore/inc/fields/slides/field_slides.php:68 -msgid "Slide" -msgstr "" - -#: ReduxCore/inc/fields/slides/field_slides.php:73 -#: ReduxCore/inc/fields/slides/field_slides.php:174 -msgid "New %s" -msgstr "" - -#: ReduxCore/inc/fields/slides/field_slides.php:145 -#: ReduxCore/inc/fields/slides/field_slides.php:200 -msgid "Title" -msgstr "" - -#: ReduxCore/inc/fields/slides/field_slides.php:149 -#: ReduxCore/inc/fields/slides/field_slides.php:204 -msgid "Description" -msgstr "" - -#: ReduxCore/inc/fields/slides/field_slides.php:153 -#: ReduxCore/inc/fields/slides/field_slides.php:207 -msgid "URL" -msgstr "" - -#: ReduxCore/inc/fields/slides/field_slides.php:167 -#: ReduxCore/inc/fields/slides/field_slides.php:220 -msgid "Delete" -msgstr "" - -#: ReduxCore/inc/fields/slides/field_slides.php:223 -msgid "Add %s" -msgstr "" - -#: ReduxCore/inc/fields/switch/field_switch.php:41 -msgid "On" -msgstr "" - -#: ReduxCore/inc/fields/switch/field_switch.php:44 -msgid "Off" -msgstr "" - -#: ReduxCore/inc/fields/typography/field_typography.php:231 -msgid "Font Family" -msgstr "" - -#: ReduxCore/inc/fields/typography/field_typography.php:232 -msgid "Font family" -msgstr "" - -#: ReduxCore/inc/fields/typography/field_typography.php:258 -#: ReduxCore/inc/fields/typography/field_typography.php:259 -msgid "Backup Font Family" -msgstr "" - -#: ReduxCore/inc/fields/typography/field_typography.php:273 -#: ReduxCore/inc/fields/typography/field_typography.php:281 -msgid "Font style" -msgstr "" - -#: ReduxCore/inc/fields/typography/field_typography.php:274 -msgid "Font Weight & Style" -msgstr "" - -#: ReduxCore/inc/fields/typography/field_typography.php:281 -msgid "Style" -msgstr "" - -#: ReduxCore/inc/fields/typography/field_typography.php:321 -msgid "Font subsets" -msgstr "" - -#: ReduxCore/inc/fields/typography/field_typography.php:323 -msgid "Font Subsets" -msgstr "" - -#: ReduxCore/inc/fields/typography/field_typography.php:325 -msgid "Subsets" -msgstr "" - -#: ReduxCore/inc/fields/typography/field_typography.php:325 -msgid "Font script" -msgstr "" - -#: ReduxCore/inc/fields/typography/field_typography.php:342 -#: ReduxCore/inc/fields/typography/field_typography.php:343 -#: ReduxCore/inc/fields/typography/field_typography.php:344 -msgid "Text Align" -msgstr "" - -#: ReduxCore/inc/fields/typography/field_typography.php:365 -#: ReduxCore/inc/fields/typography/field_typography.php:366 -#: ReduxCore/inc/fields/typography/field_typography.php:367 -msgid "Text Transform" -msgstr "" - -#: ReduxCore/inc/fields/typography/field_typography.php:388 -#: ReduxCore/inc/fields/typography/field_typography.php:389 -#: ReduxCore/inc/fields/typography/field_typography.php:390 -msgid "Font Variant" -msgstr "" - -#: ReduxCore/inc/fields/typography/field_typography.php:408 -#: ReduxCore/inc/fields/typography/field_typography.php:409 -#: ReduxCore/inc/fields/typography/field_typography.php:410 -msgid "Text Decoration" -msgstr "" - -#: ReduxCore/inc/fields/typography/field_typography.php:432 -#: ReduxCore/inc/fields/typography/field_typography.php:433 -msgid "Font Size" -msgstr "" - -#: ReduxCore/inc/fields/typography/field_typography.php:433 -msgid "Size" -msgstr "" - -#: ReduxCore/inc/fields/typography/field_typography.php:441 -#: ReduxCore/inc/fields/typography/field_typography.php:442 -msgid "Line Height" -msgstr "" - -#: ReduxCore/inc/fields/typography/field_typography.php:450 -#: ReduxCore/inc/fields/typography/field_typography.php:451 -msgid "Word Spacing" -msgstr "" - -#: ReduxCore/inc/fields/typography/field_typography.php:459 -#: ReduxCore/inc/fields/typography/field_typography.php:460 -msgid "Letter Spacing" -msgstr "" - -#: ReduxCore/inc/fields/typography/field_typography.php:478 -msgid "Font Color" -msgstr "" - -#: ReduxCore/inc/fields/typography/field_typography.php:480 -msgid "Font color" -msgstr "" - -#: ReduxCore/inc/fields/typography/field_typography.php:879 -msgid "Standard Fonts" -msgstr "" - -#: ReduxCore/inc/fields/typography/field_typography.php:980 -msgid "Google Webfonts" -msgstr "" - -#: ReduxCore/inc/tracking.php:129 -msgid "Help improve Our Panel" -msgstr "" - -#: ReduxCore/inc/tracking.php:130 -msgid "" -"Please helps us improve our panel by allowing us to gather anonymous usage " -"stats so we know which configurations, plugins and themes to test to ensure " -"compatibility." -msgstr "" - -#: ReduxCore/inc/tracking.php:135 -msgid "Allow tracking" -msgstr "" - -#: ReduxCore/inc/tracking.php:140 -msgid "Do not allow tracking" -msgstr "" - -#: ReduxCore/inc/tracking.php:151 -msgid "Welcome to the Redux Demo Panel" -msgstr "" - -#: ReduxCore/inc/tracking.php:152 -msgid "Getting Started" -msgstr "" - -#: ReduxCore/inc/tracking.php:152 -msgid "" -"This panel demonstrates the many features of Redux. Before digging in, we " -"suggest you get up to speed by reviewing %1$s." -msgstr "" - -#: ReduxCore/inc/tracking.php:152 -msgid "our documentation" -msgstr "" - -#: ReduxCore/inc/tracking.php:153 -msgid "Redux Generator" -msgstr "" - -#: ReduxCore/inc/tracking.php:153 -msgid "" -"Want to get a head start? Use the %1$s. It will create a customized " -"boilerplate theme or a standalone admin folder complete with all things " -"Redux (with the help of Underscores and TGM). Save yourself a headache and " -"try it today." -msgstr "" - -#: ReduxCore/inc/tracking.php:154 ReduxCore/inc/welcome/welcome.php:214 -msgid "Redux Extensions" -msgstr "" - -#: ReduxCore/inc/tracking.php:154 -msgid "" -"Did you know we have extensions, which greatly enhance the features of " -"Redux? Visit our %1$s to learn more!" -msgstr "" - -#: ReduxCore/inc/tracking.php:154 -msgid "extensions directory" -msgstr "" - -#: ReduxCore/inc/tracking.php:155 -msgid "Like Redux?" -msgstr "" - -#: ReduxCore/inc/tracking.php:155 -msgid "" -"If so, please %1$s and consider making a %2$s to keep development of Redux " -"moving forward." -msgstr "" - -#: ReduxCore/inc/tracking.php:155 -msgid "leave us a favorable review on WordPress.org" -msgstr "" - -#: ReduxCore/inc/tracking.php:155 -msgid "donation" -msgstr "" - -#: ReduxCore/inc/tracking.php:156 -msgid "Newsletter" -msgstr "" - -#: ReduxCore/inc/tracking.php:156 -msgid "" -"If you'd like to keep up to with all things Redux, please subscribe to our " -"newsletter" -msgstr "" - -#: ReduxCore/inc/tracking.php:157 -msgid "Email address" -msgstr "" - -#: ReduxCore/inc/tracking.php:157 -msgid "Subscribe" -msgstr "" - -#: ReduxCore/inc/tracking.php:166 -msgid "Close" -msgstr "" - -#: ReduxCore/inc/validation/color/validation_color.php:15 -#: ReduxCore/inc/validation/color_rgba/validation_color_rgba.php:14 -#: ReduxCore/inc/validation/colorrgba/validation_colorrgba.php:16 -msgid "This field must be a valid color value." -msgstr "" - -#: ReduxCore/inc/validation/comma_numeric/validation_comma_numeric.php:16 -msgid "You must provide a comma separated list of numerical values for this option." -msgstr "" - -#: ReduxCore/inc/validation/css/validation_css.php:38 -msgid "Unsafe strings were found in your CSS and have been filtered out." -msgstr "" - -#: ReduxCore/inc/validation/date/validation_date.php:16 -msgid "This field must be a valid date." -msgstr "" - -#: ReduxCore/inc/validation/email/validation_email.php:16 -#: ReduxCore/inc/validation/email_not_empty/validation_email_not_empty.php:16 -msgid "You must provide a valid email for this option." -msgstr "" - -#: ReduxCore/inc/validation/no_html/validation_no_html.php:15 -msgid "You must not enter any HTML in this field, all HTML tags have been removed." -msgstr "" - -#: ReduxCore/inc/validation/no_special_chars/validation_no_special_chars.php:16 -msgid "" -"You must not enter any special characters in this field, all special " -"characters have been removed." -msgstr "" - -#: ReduxCore/inc/validation/not_empty/validation_not_empty.php:16 -msgid "This field cannot be empty. Please provide a value." -msgstr "" - -#: ReduxCore/inc/validation/numeric/validation_numeric.php:16 -#: ReduxCore/inc/validation/numeric_not_empty/validation_numeric_not_empty.php:16 -msgid "You must provide a numerical value for this option." -msgstr "" - -#: ReduxCore/inc/validation/unique_slug/validation_unique_slug.php:16 -msgid "" -"That URL slug is in use, please choose another. %s is open for " -"use." -msgstr "" - -#: ReduxCore/inc/validation/url/validation_url.php:16 -msgid "You must provide a valid URL for this option." -msgstr "" - -#: ReduxCore/inc/welcome/views/about.php:2 -msgid "Welcome to Redux Framework %s" -msgstr "" - -#: ReduxCore/inc/welcome/views/about.php:5 -msgid "" -"Thank you for updating to the latest version! Redux Framework %s is a huge " -"step forward in Redux Development. Look at all that's new." -msgstr "" - -#: ReduxCore/inc/welcome/views/about.php:8 -#: ReduxCore/inc/welcome/views/changelog.php:8 -#: ReduxCore/inc/welcome/views/credits.php:8 -#: ReduxCore/inc/welcome/views/extensions.php:82 -#: ReduxCore/inc/welcome/views/status_report.php:31 -#: ReduxCore/inc/welcome/views/support.php:8 -msgid "Version %s" -msgstr "" - -#: ReduxCore/inc/welcome/views/about.php:15 -msgid "What is Redux Framework?" -msgstr "" - -#: ReduxCore/inc/welcome/views/about.php:17 -msgid "" -"Redux Framework is the core of many products on the web. It is an option " -"framework which developers use to\n" -" enhance their products." -msgstr "" - -#: ReduxCore/inc/welcome/views/about.php:22 -msgid "Learn More" -msgstr "" - -#: ReduxCore/inc/welcome/views/about.php:28 -msgid "New in this Release" -msgstr "" - -#: ReduxCore/inc/welcome/views/changelog.php:2 -msgid "Redux Framework - Changelog" -msgstr "" - -#: ReduxCore/inc/welcome/views/changelog.php:5 -#: ReduxCore/inc/welcome/views/status_report.php:28 -msgid "" -"Our core mantra at Redux is backwards compatibility. With hundreds of " -"thousands of instances worldwide, you can be assured that we will take care " -"of you and your clients." -msgstr "" - -#: ReduxCore/inc/welcome/views/credits.php:2 -msgid "Redux Framework - A Community Effort" -msgstr "" - -#: ReduxCore/inc/welcome/views/credits.php:5 -msgid "" -"We recognize we are nothing without our community. We would like to thank " -"all of those who help Redux to be what it is. Thank you for your " -"involvement." -msgstr "" - -#: ReduxCore/inc/welcome/views/credits.php:14 -msgid "" -"Redux is created by a community of developers world wide. Want to have your " -"name listed too? Contribute to Redux." -msgstr "" - -#: ReduxCore/inc/welcome/views/extensions.php:76 -msgid "Redux Framework - Extensions" -msgstr "" - -#: ReduxCore/inc/welcome/views/extensions.php:79 -msgid "" -"Supercharge your Redux experience. Our extensions provide you with features " -"that will take your products to the next level." -msgstr "" - -#: ReduxCore/inc/welcome/views/extensions.php:88 -msgid "" -"While some are built specificially for developers, extensions such as " -"Custom Fonts are sure to make any user happy." -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:25 -msgid "Redux Framework - System Status" -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:38 -msgid "" -"Please copy and paste this information in your ticket when contacting " -"support:" -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:41 -msgid "Get System Report" -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:44 -msgid "Understanding the Status Report" -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:51 -msgid "Copied!" -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:51 -msgid "Copy for Support" -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:60 -msgid "WordPress Environment" -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:65 -msgid "Home URL" -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:66 -msgid "The URL of your site's homepage." -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:70 -msgid "Site URL" -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:71 -msgid "The root URL of your site." -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:75 -msgid "Redux Version" -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:76 -msgid "The version of Redux Framework installed on your site." -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:80 -msgid "Redux Data Directory Writable" -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:83 -msgid "" -"Redux and its extensions write data to the uploads directory. " -"This directory must be writable." -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:88 -msgid "To allow data saving, make %s writable." -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:93 -msgid "WP Content URL" -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:96 -msgid "The location of Wordpress's content URL." -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:102 -msgid "WP Version" -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:103 -msgid "The version of WordPress installed on your site." -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:107 -msgid "WP Multisite" -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:108 -msgid "Whether or not you have WordPress Multisite enabled." -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:116 -msgid "Permalink Structure" -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:117 -msgid "" -"The current permalink structure as defined in Wordpress " -"Settings->Permalinks." -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:122 -msgid "Front Page Display" -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:123 -msgid "The current Reading mode of Wordpress." -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:131 -msgid "Front Page" -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:132 -msgid "The currently selected page which acts as the site's Front Page." -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:136 -msgid "Posts Page" -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:137 -msgid "The currently selected page in where blog posts are displayed." -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:144 -msgid "WP Memory Limit" -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:145 -msgid "The maximum amount of memory (RAM) that your site can use at one time." -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:150 -msgid "" -"%s - We recommend setting memory to at least 40MB. See: Increasing memory allocated to PHP" -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:157 -msgid "Database Table Prefix" -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:159 -msgid "The prefix structure of the current Wordpress database." -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:163 -msgid "WP Debug Mode" -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:164 -msgid "Displays whether or not WordPress is in Debug Mode." -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:172 -msgid "Language" -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:173 -msgid "The current language used by WordPress. Default = English" -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:181 -msgid "Browser" -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:186 -msgid "Browser Info" -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:187 -msgid "Information about web browser current in use." -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:202 -msgid "Server Environment" -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:207 -msgid "Server Info" -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:208 -msgid "Information about the web server that is currently hosting your site." -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:212 -msgid "Localhost Environment" -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:213 -msgid "Is the server running in a localhost environment." -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:223 -msgid "PHP Version" -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:224 -msgid "The version of PHP installed on your hosting server." -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:228 -msgid "ABSPATH" -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:229 -msgid "The ABSPATH variable on the server." -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:235 -msgid "PHP Memory Limit" -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:236 -#: ReduxCore/inc/welcome/views/status_report.php:241 -msgid "The largest filesize that can be contained in one post." -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:240 -msgid "PHP Post Max Size" -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:245 -msgid "PHP Time Limit" -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:246 -msgid "" -"The amount of time (in seconds) that your site will spend on a single " -"operation before timing out (to avoid server lockups)" -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:250 -msgid "PHP Max Input Vars" -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:251 -msgid "" -"The maximum number of variables your server can use for a single function " -"to avoid overloads." -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:255 -msgid "PHP Display Errors" -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:256 -msgid "Determines if PHP will display errors within the browser." -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:267 -msgid "SUHOSIN Installed" -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:268 -msgid "" -"Suhosin is an advanced protection system for PHP installations. It was " -"designed to protect your servers on the one hand against a number of well " -"known problems in PHP applications and on the other hand against potential " -"unknown vulnerabilities within these applications or the PHP core itself. " -"If enabled on your server, Suhosin may need to be configured to increase " -"its data submission limits." -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:277 -msgid "MySQL Version" -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:278 -msgid "The version of MySQL installed on your hosting server." -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:282 -msgid "Max Upload Size" -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:283 -msgid "The largest filesize that can be uploaded to your WordPress installation." -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:287 -msgid "Default Timezone is UTC" -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:290 -msgid "The default timezone for your server." -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:293 -msgid "Default timezone is %s - it should be UTC" -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:304 -msgid "Used when communicating with remote services with PHP." -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:310 -msgid "" -"Your server does not have fsockopen or cURL enabled - cURL is used to " -"communicate with other servers. Please contact your hosting provider." -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:349 -msgid "Remote Post" -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:350 -msgid "Used to send data to remote servers." -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:355 -msgid "" -"wp_remote_post() failed. Many advanced features may not function. Contact " -"your hosting provider." -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:358 -#: ReduxCore/inc/welcome/views/status_report.php:373 -msgid "Error: %s" -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:365 -msgid "Remote Get" -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:366 -msgid "Used to grab information from remote servers for updates updates." -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:371 -msgid "" -"wp_remote_get() failed. This is needed to get information from remote " -"servers. Contact your hosting provider." -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:405 -msgid "Active Plugins" -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:421 -msgid "Visit plugin homepage" -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:445 -msgid "Redux Instance: " -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:452 -msgid "The opt_name argument for this instance of Redux." -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:460 -msgid "The global_variable argument for this instance of Redux." -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:468 -msgid "Indicates if developer mode is enabled for this instance of Redux." -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:473 -msgid "Indicates if ajax based saving is enabled for this instance of Redux." -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:478 -msgid "" -"The page slug denotes the string used for the options panel page for this " -"instance of Redux." -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:483 -msgid "" -"The page permissions variable sets the permission level required to access " -"the options panel for this instance of Redux." -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:488 -msgid "" -"This variable set whether or not the menu is displayed as an admin menu " -"item for this instance of Redux." -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:493 -msgid "" -"The page parent variable sets where the options menu will be placed on the " -"WordPress admin sidebar for this instance of Redux." -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:499 -msgid "Indicates if the compiler flag is enabled for this instance of Redux." -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:504 -msgid "" -"Indicates if output flag for globally shutting off all CSS output is " -"enabled for this instance of Redux." -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:509 -msgid "" -"The output_tag variable sets whether or not dynamic CSS will be generated " -"for the customizer and Google fonts for this instance of Redux." -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:518 -msgid "" -"The specified template path containing custom template files for this " -"instance of Redux." -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:523 -msgid "List of template files overriding the default Redux template files." -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:546 -msgid "Indicates the installed Redux extensions and their version numbers." -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:577 -msgid "Theme" -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:582 -msgid "Name" -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:583 -msgid "The name of the current active theme." -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:587 -msgid "Version" -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:588 -msgid "The installed version of the current active theme." -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:593 -msgid "is available" -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:598 -msgid "Author URL" -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:599 -msgid "The theme developers URL." -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:603 -msgid "Child Theme" -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:604 -msgid "Displays whether or not the current theme is a child theme." -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:606 -msgid "" -"If you're modifying Redux Framework or a parent theme you didn't build " -"personally, we recommend using a child theme. See: How to create a child theme" -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:614 -msgid "Parent Theme Name" -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:616 -msgid "The name of the parent theme." -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:620 -msgid "Parent Theme Version" -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:623 -msgid "The installed version of the parent theme." -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:627 -msgid "Parent Theme Author URL" -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:630 -msgid "The parent theme developers URL." -msgstr "" - -#: ReduxCore/inc/welcome/views/support.php:2 -msgid "Redux Framework - Support" -msgstr "" - -#: ReduxCore/inc/welcome/views/support.php:5 -msgid "" -"We are an open source project used by developers to make powerful control " -"panels." -msgstr "" - -#: ReduxCore/inc/welcome/views/support.php:20 -msgid "Generate a Support URL" -msgstr "" - -#: ReduxCore/inc/welcome/views/support.php:21 -msgid "Select Support Type" -msgstr "" - -#: ReduxCore/inc/welcome/views/support.php:22 -#: ReduxCore/inc/welcome/views/support.php:65 -msgid "How to Get Support" -msgstr "" - -#: ReduxCore/inc/welcome/views/support.php:27 -msgid "Submit a Support Request" -msgstr "" - -#: ReduxCore/inc/welcome/views/support.php:30 -msgid "To get started, we will need to generate a support hash." -msgstr "" - -#: ReduxCore/inc/welcome/views/support.php:33 -msgid "" -"This will provide to your developer all the information they may need to " -"remedy your issue. This action WILL send information securely to a remote " -"server. To see the type of information sent, please look at the Status tab." -msgstr "" - -#: ReduxCore/inc/welcome/views/support.php:37 -msgid "" -"Generate\n" -" a Support URL" -msgstr "" - -#: ReduxCore/inc/welcome/views/support.php:44 -msgid "Select Your Support Type" -msgstr "" - -#: ReduxCore/inc/welcome/views/support.php:47 -msgid "What type of user are you?" -msgstr "" - -#: ReduxCore/inc/welcome/views/support.php:52 -msgid "User" -msgstr "" - -#: ReduxCore/inc/welcome/views/support.php:53 -msgid "I am a user, using a pre-built product." -msgstr "" - -#: ReduxCore/inc/welcome/views/support.php:56 -msgid "Developer" -msgstr "" - -#: ReduxCore/inc/welcome/views/support.php:57 -msgid "I am a developer, building a product using Redux." -msgstr "" - -#: ReduxCore/inc/welcome/views/support.php:68 -msgid "" -"Please proceed to the Redux Framework issue tracker and supply us with your " -"support URL below. Please also provide any information that will help us to " -"reproduce your issue." -msgstr "" - -#: ReduxCore/inc/welcome/views/support.php:74 -msgid "" -"Listed below are the Wordpress plugins and/or theme installed on your site " -"that utilize Redux Framework. We do not directly support products created " -"with our framework. It is the responsibility of the plugin or theme " -"developer to support their work. You will need to contact the author(s) of " -"the products listed below with your support questions." -msgstr "" - -#: ReduxCore/inc/welcome/views/support.php:77 -msgid "" -"Please be sure to include for your developer - via cut and paste - the " -"Support URL in the box below." -msgstr "" - -#: ReduxCore/inc/welcome/views/support.php:215 -msgid "" -"Should the developer not be responsive, read the following article before asking for support from us " -"directly." -msgstr "" - -#: ReduxCore/inc/welcome/welcome.php:170 -msgid "Support hash could not be generated. Please try again later." -msgstr "" - -#: ReduxCore/inc/welcome/welcome.php:190 -msgid "Welcome to Redux Framework" -msgstr "" - -#: ReduxCore/inc/welcome/welcome.php:198 -msgid "Redux Framework Changelog" -msgstr "" - -#: ReduxCore/inc/welcome/welcome.php:206 class.redux-plugin.php:411 -msgid "Get Support" -msgstr "" - -#: ReduxCore/inc/welcome/welcome.php:223 -msgid "The people that develop Redux Framework" -msgstr "" - -#: ReduxCore/inc/welcome/welcome.php:231 -msgid "Redux Framework Status" -msgstr "" - -#: ReduxCore/inc/welcome/welcome.php:336 -msgid "What's New" -msgstr "" - -#: ReduxCore/inc/welcome/welcome.php:340 -msgid "Extensions" -msgstr "" - -#: ReduxCore/inc/welcome/welcome.php:344 -msgid "Changelog" -msgstr "" - -#: ReduxCore/inc/welcome/welcome.php:348 -msgid "Credits" -msgstr "" - -#: ReduxCore/inc/welcome/welcome.php:352 -msgid "Support" -msgstr "" - -#: ReduxCore/inc/welcome/welcome.php:356 -msgid "Status" -msgstr "" - -#: ReduxCore/inc/welcome/welcome.php:513 -msgid "View %s" -msgstr "" - -#: ReduxCore/templates/panel/footer.tpl.php:47 -#: ReduxCore/templates/panel/header_stickybar.tpl.php:20 -msgid "Save Changes" -msgstr "" - -#: ReduxCore/templates/panel/footer.tpl.php:50 -#: ReduxCore/templates/panel/header_stickybar.tpl.php:22 -msgid "Reset Section" -msgstr "" - -#: ReduxCore/templates/panel/footer.tpl.php:51 -#: ReduxCore/templates/panel/header_stickybar.tpl.php:23 -msgid "Reset All" -msgstr "" - -#: ReduxCore/templates/panel/footer.tpl.php:56 -#: ReduxCore/templates/panel/header_stickybar.tpl.php:26 -msgid "Working..." -msgstr "" - -#: ReduxCore/templates/panel/header.tpl.php:18 -msgid "Developer Mode Enabled" -msgstr "" - -#: ReduxCore/templates/panel/header_stickybar.tpl.php:16 -msgid "Expand" -msgstr "" - -#: class.redux-plugin.php:307 -msgid "Redux Framework has an embedded demo." -msgstr "" - -#: class.redux-plugin.php:307 -msgid "Click here to activate the sample config file." -msgstr "" - -#: class.redux-plugin.php:408 -msgid "Docs" -msgstr "" - -#: class.redux-plugin.php:409 -msgid "Repo" -msgstr "" - -#: class.redux-plugin.php:410 -msgid "Builder" -msgstr "" - -#: class.redux-plugin.php:416 -msgid "Deactivate Demo Mode" -msgstr "" - -#: class.redux-plugin.php:418 -msgid "Activate Demo Mode" -msgstr "" - -#: tests/includes/class-tivwp-dm-controller.php:28 -msgid "Must call in of after the \"plugins_loaded\" action." -msgstr "" - -#: tests/includes/class-tivwp-dm-controller.php:138 -msgid "Unknown action \"%1$s\" specified for %2$s" -msgstr "" - -#: tests/includes/class-tivwp-dm-controller.php:143 -msgid "The unknown action has been replaced with \"%s\"" -msgstr "" - -#: tests/includes/class-tivwp-dm-controller.php:158 -msgid "Automatic action performed: \"%s\"" -msgstr "" - -#: tests/includes/class-tivwp-dm.php:112 -msgid "Activate Development Plugins" -msgstr "" - -#: tests/includes/class-tivwp-dm.php:119 -msgid "Deactivate Development Plugins" -msgstr "" - -#: tests/includes/class-tivwp-dm.php:131 -msgid "You do not have sufficient permissions to access this page." -msgstr "" - -#. Plugin URI of the plugin/theme -msgid "http://wordpress.org/plugins/redux-framework" -msgstr "" - -#. Description of the plugin/theme -msgid "" -"Redux is a simple, truly extensible options framework for WordPress themes " -"and plugins." -msgstr "" - -#. Author of the plugin/theme -msgid "Team Redux" -msgstr "" - -#. Author URI of the plugin/theme -msgid "http://reduxframework.com" -msgstr "" - -#: ReduxCore/inc/welcome/views/status_report.php:427 -msgctxt "by author" -msgid "by %s" -msgstr "" \ No newline at end of file diff --git a/library/admin/ReduxCore/languages/ro_RO.mo b/library/admin/ReduxCore/languages/ro_RO.mo deleted file mode 100644 index 070cab6e..00000000 Binary files a/library/admin/ReduxCore/languages/ro_RO.mo and /dev/null differ diff --git a/library/admin/ReduxCore/languages/ru_RU.mo b/library/admin/ReduxCore/languages/ru_RU.mo deleted file mode 100644 index 19e9d1f2..00000000 Binary files a/library/admin/ReduxCore/languages/ru_RU.mo and /dev/null differ diff --git a/library/admin/ReduxCore/languages/sk_SK.mo b/library/admin/ReduxCore/languages/sk_SK.mo deleted file mode 100644 index 2b7ea22b..00000000 Binary files a/library/admin/ReduxCore/languages/sk_SK.mo and /dev/null differ diff --git a/library/admin/ReduxCore/languages/sl_SI.mo b/library/admin/ReduxCore/languages/sl_SI.mo deleted file mode 100644 index 41358aae..00000000 Binary files a/library/admin/ReduxCore/languages/sl_SI.mo and /dev/null differ diff --git a/library/admin/ReduxCore/languages/sv_SE.mo b/library/admin/ReduxCore/languages/sv_SE.mo deleted file mode 100644 index 9ce07b9f..00000000 Binary files a/library/admin/ReduxCore/languages/sv_SE.mo and /dev/null differ diff --git a/library/admin/ReduxCore/languages/th.mo b/library/admin/ReduxCore/languages/th.mo deleted file mode 100644 index 5fb244a5..00000000 Binary files a/library/admin/ReduxCore/languages/th.mo and /dev/null differ diff --git a/library/admin/ReduxCore/languages/tr_TR.mo b/library/admin/ReduxCore/languages/tr_TR.mo deleted file mode 100644 index 38cb0009..00000000 Binary files a/library/admin/ReduxCore/languages/tr_TR.mo and /dev/null differ diff --git a/library/admin/ReduxCore/languages/zh_CN.mo b/library/admin/ReduxCore/languages/zh_CN.mo deleted file mode 100644 index dd38781d..00000000 Binary files a/library/admin/ReduxCore/languages/zh_CN.mo and /dev/null differ diff --git a/library/admin/ReduxCore/templates/panel/container.tpl.php b/library/admin/ReduxCore/templates/panel/container.tpl.php deleted file mode 100644 index 2713d466..00000000 --- a/library/admin/ReduxCore/templates/panel/container.tpl.php +++ /dev/null @@ -1,50 +0,0 @@ -parent->args['open_expanded'] ) ? ' fully-expanded' : '' . ( ! empty( $this->parent->args['class'] ) ? ' ' . esc_attr( $this->parent->args['class'] ) : '' ); - $nonce = wp_create_nonce( "redux_ajax_nonce" ); -?> -
    - parent->args['database'] == "network" && $this->parent->args['network_admin'] && is_network_admin() ? './edit.php?action=redux_' . $this->parent->args['opt_name'] : './options.php' ) ?> -
    - parent->args['opt_name'] is sanitized in the Framework class, no need to re-sanitize it. ?> - - parent->args['opt_name'] is sanitized in the Framework class, no need to re-sanitize it. ?> - - parent->args['opt_name'] is sanitized in the Framework class, no need to re-sanitize it. ?> - parent->no_panel ) ) : ?> - - - init_settings_fields(); - - // Last tab? - $this->parent->options['last_tab'] = ( isset( $_GET['tab'] ) && ! isset( $this->parent->transients['last_save_mode'] ) ) ? $_GET['tab'] : ''; - ?> - parent->args['opt_name'] is sanitized in the Framework class, no need to re-sanitize it. ?> - - - get_template( 'content.tpl.php' ); ?> - -
    -
    - -parent->args['footer_text'] ) ) : ?> - - diff --git a/library/admin/ReduxCore/templates/panel/content.tpl.php b/library/admin/ReduxCore/templates/panel/content.tpl.php deleted file mode 100644 index 8af928fc..00000000 --- a/library/admin/ReduxCore/templates/panel/content.tpl.php +++ /dev/null @@ -1,99 +0,0 @@ - - -get_template( 'header.tpl.php' ); ?> - - -parent->args['intro_text'] ) ) { ?> -
    parent->args['intro_text'] ); ?>
    - - -get_template( 'menu_container.tpl.php' ); ?> - -
    - - get_template( 'header_stickybar.tpl.php' ); ?> -
     
    - parent->sections as $k => $section) { - if ( isset( $section['customizer_only'] ) && $section['customizer_only'] == true ) { - continue; - } - - //$active = ( ( is_numeric($this->parent->current_tab) && $this->parent->current_tab == $k ) || ( !is_numeric($this->parent->current_tab) && $this->parent->current_tab === $k ) ) ? ' style="display: block;"' : ''; - $section['class'] = isset( $section['class'] ) ? ' ' . $section['class'] : ''; - echo '
    '; - //echo '
    '; - - echo '
      '; - - foreach ($section['tab'] as $subkey => $subsection) { - //echo '-=' . $subkey . '=-'; - echo '
    • ' . $subsection['title'] . '
    • '; - } - - echo '
    '; - foreach ($section['tab'] as $subkey => $subsection) { - echo '
    '; - echo '
    '; - echo "hello ".$subkey; - do_settings_sections( $this->parent->args['opt_name'] . $k . '_tab_' . $subkey . '_section_group' ); - echo "
    "; - echo "
    "; - } - echo "
    "; - } else { - */ - - // Don't display in the - $display = true; - if ( isset( $_GET['page'] ) && $_GET['page'] == $this->parent->args['page_slug'] ) { - if ( isset( $section['panel'] ) && $section['panel'] == "false" ) { - $display = false; - } - } - - if ( $display ) { - do_action( "redux/page/{$this->parent->args['opt_name']}/section/before", $section ); - $this->output_section( $k ); - do_action( "redux/page/{$this->parent->args['opt_name']}/section/after", $section ); - } - //} - ?>
    '; - } - - /** - * action 'redux/page-after-sections-{opt_name}' - * - * @deprecated - * - * @param object $this ReduxFramework - */ - do_action( "redux/page-after-sections-{$this->parent->args['opt_name']}", $this ); // REMOVE LATER - - /** - * action 'redux/page/{opt_name}/sections/after' - * - * @param object $this ReduxFramework - */ - do_action( "redux/page/{$this->parent->args['opt_name']}/sections/after", $this ); -?> -
    - -get_template( 'footer.tpl.php' ); ?> - -
    -
    \ No newline at end of file diff --git a/library/admin/ReduxCore/templates/panel/footer.tpl.php b/library/admin/ReduxCore/templates/panel/footer.tpl.php deleted file mode 100644 index ff402182..00000000 --- a/library/admin/ReduxCore/templates/panel/footer.tpl.php +++ /dev/null @@ -1,61 +0,0 @@ - - - diff --git a/library/admin/ReduxCore/templates/panel/header.tpl.php b/library/admin/ReduxCore/templates/panel/header.tpl.php deleted file mode 100644 index 2fcbc8d0..00000000 --- a/library/admin/ReduxCore/templates/panel/header.tpl.php +++ /dev/null @@ -1,73 +0,0 @@ -parent->dev_mode_forced ) { - $is_debug = false; - $is_localhost = false; - - $debug_bit = ''; - if ( Redux_Helpers::isWpDebug() ) { - $is_debug = true; - $debug_bit = __( 'WP_DEBUG is enabled', 'redux-framework' ); - } - - $localhost_bit = ''; - if ( Redux_Helpers::isLocalHost() ) { - $is_localhost = true; - $localhost_bit = __( 'you are working in a localhost environment', 'redux-framework' ); - } - - $conjunction_bit = ''; - if ( $is_localhost && $is_debug ) { - $conjunction_bit = ' ' . __( 'and', 'redux-framework' ) . ' '; - } - - $tip_msg = __( 'This has been automatically enabled because', 'redux-framework' ) . ' ' . $debug_bit . $conjunction_bit . $localhost_bit . '.'; - } else { - $tip_msg = __( 'If you are not a developer, your theme/plugin author shipped with developer mode enabled. Contact them directly to fix it.', 'redux-framework' ); - } - -?> -
    - parent->args['display_name'] ) ) { ?> -
    - - parent->args['dev_mode'] ) && $this->parent->args['dev_mode'] ) { ?> -
    - -
    - parent->args['forced_dev_mode_off']) && $this->parent->args['forced_dev_mode_off'] == true ) { ?> - - -
    - -
    - - - -

    parent->args['display_name'] ); ?>

    - - parent->args['display_version'] ) ) { ?> - parent->args['display_version'] ); ?> - - -
    - - -
    -
    \ No newline at end of file diff --git a/library/admin/ReduxCore/templates/panel/header_stickybar.tpl.php b/library/admin/ReduxCore/templates/panel/header_stickybar.tpl.php deleted file mode 100644 index 645a83fb..00000000 --- a/library/admin/ReduxCore/templates/panel/header_stickybar.tpl.php +++ /dev/null @@ -1,35 +0,0 @@ - -
    -
    - - parent->args['hide_expand'] ? ' style="display: none;"' : '' ?>> - -
    - - - parent->args['hide_reset'] ) : ?> - parent->args['opt_name'] . '[defaults-section]', false, array( 'id' => 'redux-defaults-section' ) ); ?> - parent->args['opt_name'] . '[defaults]', false, array( 'id' => 'redux-defaults' ) ); ?> - -
    -
     
    -
    -
    - - -
    - notification_bar(); ?> -
    - - -
    \ No newline at end of file diff --git a/library/admin/ReduxCore/templates/panel/menu_container.tpl.php b/library/admin/ReduxCore/templates/panel/menu_container.tpl.php deleted file mode 100644 index 0fb39436..00000000 --- a/library/admin/ReduxCore/templates/panel/menu_container.tpl.php +++ /dev/null @@ -1,51 +0,0 @@ - -
    -
      -parent->sections as $k => $section ) { - $title = isset ( $section[ 'title' ] ) ? $section[ 'title' ] : ''; - - $skip_sec = false; - foreach ( $this->parent->hidden_perm_sections as $num => $section_title ) { - if ( $section_title == $title ) { - $skip_sec = true; - } - } - - if ( isset ( $section[ 'customizer_only' ] ) && $section[ 'customizer_only' ] == true ) { - continue; - } - - if ( false == $skip_sec ) { - echo $this->parent->section_menu ( $k, $section ); - $skip_sec = false; - } - } - - /** - * action 'redux-page-after-sections-menu-{opt_name}' - * - * @param object $this ReduxFramework - */ - do_action ( "redux-page-after-sections-menu-{$this->parent->args[ 'opt_name' ]}", $this ); - - /** - * action 'redux/page/{opt_name}/menu/after' - * - * @param object $this ReduxFramework - */ - do_action ( "redux/page/{$this->parent->args[ 'opt_name' ]}/menu/after", $this ); -?> -
    -
    \ No newline at end of file diff --git a/library/admin/bin/CNAME b/library/admin/bin/CNAME deleted file mode 100644 index a8ad8b83..00000000 --- a/library/admin/bin/CNAME +++ /dev/null @@ -1 +0,0 @@ -codex.reduxframework.com \ No newline at end of file diff --git a/library/admin/bin/commit-uncompressed-files.sh b/library/admin/bin/commit-uncompressed-files.sh deleted file mode 100644 index 6c39d782..00000000 --- a/library/admin/bin/commit-uncompressed-files.sh +++ /dev/null @@ -1,23 +0,0 @@ -if [[ "$TRAVIS_PULL_REQUEST" == "false" && "$TRAVIS_JOB_NUMBER" == *.1 ]]; then - - echo -e "Checking to make sure files are properly compressed.\n" - - v1=`find ReduxCore -type f | sort -u | xargs cat | md5sum` - echo "$v1" - grunt compileCSS - grunt compileJS - v2=`find ReduxCore -type f | sort -u | xargs cat | md5sum` - echo "$v2" - if [ "$v1" == "$v2" ]; then - echo "All files are properly compressed." - else - echo "Files are not the same. Need to commit back to the repo." - #git config --global user.email "travis@travis-ci.org" - #git config --global user.name "Travis" - #git remote set-url origin "https://$GH_TOKEN@github.com/ReduxFramework/ReduxFramework.git" - #git status - #git commit -a "Committing compressed files back to repo." - #git push origin HEAD:$TRAVIS_BRANCH - fi - -fi diff --git a/library/admin/bin/install-wp-tests.sh b/library/admin/bin/install-wp-tests.sh deleted file mode 100644 index 2045fec6..00000000 --- a/library/admin/bin/install-wp-tests.sh +++ /dev/null @@ -1,91 +0,0 @@ -#!/usr/bin/env bash - -if [ $# -lt 3 ]; then - echo "usage: $0 [db-host] [wp-version]" - exit 1 -fi - -DB_NAME=$1 -DB_USER=$2 -DB_PASS=$3 -DB_HOST=${4-localhost} -WP_VERSION=${5-latest} - -# set dir vars -DIR_WP_DEVELOP=tmp-wp-dev -WP_CORE_DIR=${DIR_WP_DEVELOP}/wordpress/ -export WP_TESTS_DIR=${DIR_WP_DEVELOP}/wordpress-tests/ - -set -ex - -# cleanup -rm -rf ${DIR_WP_DEVELOP} -mysql -e "DROP DATABASE IF EXISTS ${DB_NAME};" --user="${DB_USER}" --password="${DB_PASS}" - -install_wp() { - mkdir -p ${WP_CORE_DIR} - - local ARCHIVE_NAME - if [ ${WP_VERSION} == 'latest' ]; then - ARCHIVE_NAME='latest' - else - ARCHIVE_NAME="wordpress-$WP_VERSION" - fi - - wget -nv -O ${DIR_WP_DEVELOP}/wordpress.tar.gz http://wordpress.org/${ARCHIVE_NAME}.tar.gz - tar --strip-components=1 -zxmf ${DIR_WP_DEVELOP}/wordpress.tar.gz -C ${WP_CORE_DIR} - rm -f ${DIR_WP_DEVELOP}/wordpress.tar.gz - -# wget -nv -O ${WP_CORE_DIR}/wp-content/db.php https://raw.github.com/markoheijnen/wp-mysqli/master/db.php -} - -install_test_suite() { - # portable in-place argument for both GNU sed and Mac OSX sed - local ioption - if [[ $(uname -s) == 'Darwin' ]]; then - ioption='-i ""' - else - ioption='-i' - fi - - # set up testing suite - mkdir -p ${WP_TESTS_DIR} - cd ${WP_TESTS_DIR} - svn co --quiet http://develop.svn.wordpress.org/trunk/tests/phpunit/includes/ . - - # setup tests config file - cd .. - wget -nv -O wp-tests-config.php http://develop.svn.wordpress.org/trunk/wp-tests-config-sample.php - - sed ${ioption} "s:dirname( __FILE__ ) . '/src/':'${WP_CORE_DIR}':" wp-tests-config.php - sed ${ioption} "s/youremptytestdbnamehere/${DB_NAME}/" wp-tests-config.php - sed ${ioption} "s/yourusernamehere/${DB_USER}/" wp-tests-config.php - sed ${ioption} "s/yourpasswordhere/${DB_PASS}/" wp-tests-config.php - sed ${ioption} "s|localhost|${DB_HOST}|" wp-tests-config.php -} - -install_db() { - # parse DB_HOST for port or socket references -# local PARTS=(${DB_HOST//\:/ }) -# local DB_HOSTNAME=${PARTS[0]}; -# local DB_SOCK_OR_PORT=${PARTS[1]}; -# local EXTRA="" -# -# if ! [ -z ${DB_HOSTNAME} ] ; then -# if [[ "${DB_SOCK_OR_PORT}" =~ ^[0-9]+$ ]] ; then -# EXTRA=" --host=${DB_HOSTNAME} --port=${DB_SOCK_OR_PORT} --protocol=tcp" -# elif ! [ -z ${DB_SOCK_OR_PORT} ] ; then -# EXTRA=" --socket=${DB_SOCK_OR_PORT}" -# elif ! [ -z ${DB_HOSTNAME} ] ; then -# EXTRA=" --host=${DB_HOSTNAME} --protocol=tcp" -# fi -# fi - - # create database - mysql -e "CREATE DATABASE IF NOT EXISTS ${DB_NAME};" --user="${DB_USER}" --password="${DB_PASS}" -# mysqladmin create ${DB_NAME} --user="$DB_USER" --password="$DB_PASS"$EXTRA -} - -install_wp -install_test_suite -install_db diff --git a/library/admin/bin/update-codex.sh b/library/admin/bin/update-codex.sh deleted file mode 100644 index 3f2a68b0..00000000 --- a/library/admin/bin/update-codex.sh +++ /dev/null @@ -1,40 +0,0 @@ -#!/usr/bin/env bash - -if [[ "$TRAVIS_PULL_REQUEST" == "false" && "$TRAVIS_JOB_NUMBER" == *.1 ]]; then - - # update the mirror repo for composer/packagist - echo -e "Pushing to composer mirror\n" - git push --mirror https://${GH_TOKEN}@github.com/redux-framework/redux-framework.git - - # Re-Deploy the heroku demo app and pull the newest code - echo -e "Starting dev demo push to Heroku\n" - git clone git@heroku.com:redux-premium.git redux-premium - cd redux-premium - git remote add heroku git@heroku.com:redux-premium.git - git reset HEAD~; git push -f heroku master; - cd .. - rm -fr redux-premium - - echo -e "Starting to update documentation\n" - - # Make sure we don't have any old files - rm -fr $HOME/docs - - # Install phpDocumentor - pear channel-discover pear.phpdoc.org - pear install phpdoc/phpDocumentor - pear install Image_GraphViz - phpenv rehash #Have to run this for travis - - # Generate the docs - grunt phpdocumentor - - # Copy the github CNAME file to the docs - cp bin/CNAME docs/ - - # Publish the docs to gh-pages - grunt gh-pages:travis - - - -fi \ No newline at end of file diff --git a/library/admin/bin/update-mirrors-docs.sh b/library/admin/bin/update-mirrors-docs.sh deleted file mode 100644 index 59fd0bba..00000000 --- a/library/admin/bin/update-mirrors-docs.sh +++ /dev/null @@ -1,49 +0,0 @@ -language: php -php: - - "5.2" - - "5.4" -env: - global: - secure: "aDIYEmgxoF/+2vwPdvmbxFKMoz8pA9vtvemehyLNvH3LF05RgFiwNNv+7Lvy127p4Fxp3VBK+ZLKUEEL1gdpevzgni9EigpK8YZbIVHXRL3U+1eP9rcnjuGF9pKuB4kB2ivzoprcalg1ZDI9PnRYRDE4YUTHJiEN2MmLys1QWdc=" - cache: - directories: - - node_modules - matrix: - - WP_VERSION=latest WP_MULTISITE=0 - - WP_VERSION=latest WP_MULTISITE=1 -install: -- npm install -g grunt-cli -- npm install -- find ReduxCore -type f | sort -u | xargs cat | md5sum > md5 -before_script: bash bin/install-wp-tests.sh wordpress_test root '' localhost $WP_VERSION -script: -- phpunit -- grunt jshint -- grunt lintPHP -after_success: - # Install the Heroku gem (or the Heroku toolbelt) - #- gem install heroku - # Add your Heroku git repo: - #- git remote add heroku git@heroku.com:redux-premium.git - # Turn off warnings about SSH keys: - #- echo "Host heroku.com" >> ~/.ssh/config - #- echo " StrictHostKeyChecking no" >> ~/.ssh/config - #- echo " CheckHostIP no" >> ~/.ssh/config - #- echo " UserKnownHostsFile=/dev/null" >> ~/.ssh/config - # Clear your current Heroku SSH keys: - #- heroku keys:clear - # Add a new SSH key to Heroku - #- yes | heroku keys:add - - ./bin/update-mirrors-docs.sh -after_script: - #- ./bin/commit-uncompressed-files.sh -notifications: - email: - recipients: - - dovy@reduxframework.com - - kevin@reduxframework.com - on_failure: always -branches: - except: - - gh-pages - - setup diff --git a/library/admin/bootstrap_tests.php b/library/admin/bootstrap_tests.php deleted file mode 100644 index 83d72b8c..00000000 --- a/library/admin/bootstrap_tests.php +++ /dev/null @@ -1,28 +0,0 @@ - array( "ReduxFramework/redux-framework.php" ), -); - -/** - * If the wordpress-tests repo location has been customized (and specified - * with WP_TESTS_DIR), use that location. This will most commonly be the case - * when configured for use with Travis CI. - * - * Otherwise, we'll just assume that this plugin is installed in the WordPress - * SVN external checkout configured in the wordpress-tests repo. - */ -if( false !== getenv( 'WP_TESTS_DIR' ) ) { - require getenv( 'WP_TESTS_DIR' ) . '/bootstrap.php'; -} else { - require dirname( dirname( dirname( dirname( dirname( __FILE__ ) ) ) ) ) . '/bootstrap.php'; -} diff --git a/library/admin/class.redux-plugin.php b/library/admin/class.redux-plugin.php deleted file mode 100644 index fae8dd9c..00000000 --- a/library/admin/class.redux-plugin.php +++ /dev/null @@ -1,433 +0,0 @@ -get_redux_options(); - self::$instance->includes(); - self::$instance->hooks(); - } - - return self::$instance; - } - - // Shim since we changed the function name. Deprecated. - public static function get_instance() { - if ( ! self::$instance ) { - self::$instance = new self; - self::$instance->get_redux_options(); - self::$instance->includes(); - self::$instance->hooks(); - } - - return self::$instance; - } - - /** - * Get Redux options - * - * @access public - * @since 3.1.3 - * @return void - */ - public function get_redux_options() { - - // Setup defaults - $defaults = array( - 'demo' => false, - ); - - // If multisite is enabled - if ( is_multisite() ) { - - // Get network activated plugins - $plugins = get_site_option( 'active_sitewide_plugins' ); - - foreach ( $plugins as $file => $plugin ) { - if ( strpos( $file, 'redux-framework.php' ) !== false ) { - $this->plugin_network_activated = true; - $this->options = get_site_option( 'ReduxFrameworkPlugin', $defaults ); - } - } - } - - // If options aren't set, grab them now! - if ( empty( $this->options ) ) { - $this->options = get_option( 'ReduxFrameworkPlugin', $defaults ); - } - } - - /** - * Include necessary files - * - * @access public - * @since 3.1.3 - * @return void - */ - public function includes() { - // Include ReduxCore - if ( file_exists( dirname( __FILE__ ) . '/ReduxCore/framework.php' ) ) { - require_once dirname( __FILE__ ) . '/ReduxCore/framework.php'; - } - - if ( isset( ReduxFramework::$_as_plugin ) ) { - ReduxFramework::$_as_plugin = true; - } - - if ( file_exists( dirname( __FILE__ ) . '/ReduxCore/redux-extensions/config.php' ) ) { - require_once dirname( __FILE__ ) . '/ReduxCore/redux-extensions/config.php'; - } - - // Include demo config, if demo mode is active - if ( $this->options['demo'] && file_exists( dirname( __FILE__ ) . '/sample/sample-config.php' ) ) { - require_once dirname( __FILE__ ) . '/sample/sample-config.php'; - } - } - - /** - * Run action and filter hooks - * - * @access private - * @since 3.1.3 - * @return void - */ - private function hooks() { - add_action( 'wp_loaded', array( $this, 'options_toggle_check' ) ); - - // Activate plugin when new blog is added - add_action( 'wpmu_new_blog', array( $this, 'activate_new_site' ) ); - - // Display admin notices - add_action( 'admin_notices', array( $this, 'admin_notices' ) ); - - // Edit plugin metalinks - add_filter( 'plugin_row_meta', array( $this, 'plugin_metalinks' ), null, 2 ); - - add_action( 'activated_plugin', array( $this, 'load_first' ) ); - - do_action( 'redux/plugin/hooks', $this ); - } - - public function load_first() { - $plugin_dir = Redux_Helpers::cleanFilePath( WP_PLUGIN_DIR ) . '/'; - $self_file = Redux_Helpers::cleanFilePath( __FILE__ ); - - $path = str_replace( $plugin_dir, '', $self_file ); - $path = str_replace( 'class.redux-plugin.php', 'redux-framework.php', $path ); - - if ( $plugins = get_option( 'active_plugins' ) ) { - if ( $key = array_search( $path, $plugins ) ) { - array_splice( $plugins, $key, 1 ); - array_unshift( $plugins, $path ); - update_option( 'active_plugins', $plugins ); - } - } - } - - /** - * Fired on plugin activation - * - * @access public - * @since 3.0.0 - * - * @param boolean $network_wide True if plugin is network activated, false otherwise - * - * @return void - */ - public static function activate( $network_wide ) { - if ( function_exists( 'is_multisite' ) && is_multisite() ) { - if ( $network_wide ) { - // Get all blog IDs - $blog_ids = self::get_blog_ids(); - - foreach ( $blog_ids as $blog_id ) { - switch_to_blog( $blog_id ); - self::single_activate(); - } - restore_current_blog(); - } else { - self::single_activate(); - } - } else { - self::single_activate(); - } - - delete_site_transient( 'update_plugins' ); - } - - /** - * Fired when plugin is deactivated - * - * @access public - * @since 3.0.0 - * - * @param boolean $network_wide True if plugin is network activated, false otherwise - * - * @return void - */ - public static function deactivate( $network_wide ) { - if ( function_exists( 'is_multisite' ) && is_multisite() ) { - if ( $network_wide ) { - // Get all blog IDs - $blog_ids = self::get_blog_ids(); - - foreach ( $blog_ids as $blog_id ) { - switch_to_blog( $blog_id ); - self::single_deactivate(); - } - restore_current_blog(); - } else { - self::single_deactivate(); - } - } else { - self::single_deactivate(); - } - - delete_option( 'ReduxFrameworkPlugin' ); - } - - /** - * Fired when a new WPMU site is activated - * - * @access public - * @since 3.0.0 - * - * @param int $blog_id The ID of the new blog - * - * @return void - */ - public function activate_new_site( $blog_id ) { - if ( 1 !== did_action( 'wpmu_new_blog' ) ) { - return; - } - - switch_to_blog( $blog_id ); - self::single_activate(); - restore_current_blog(); - } - - /** - * Get all IDs of blogs that are not activated, not spam, and not deleted - * - * @access private - * @since 3.0.0 - * @global object $wpdb - * @return array|false Array of IDs or false if none are found - */ - private static function get_blog_ids() { - global $wpdb; - - // Get an array of IDs - $sql = "SELECT blog_id FROM $wpdb->blogs - WHERE archived = '0' AND spam = '0' - AND deleted = '0'"; - - return $wpdb->get_col( $sql ); - } - - /** - * Fired for each WPMS blog on plugin activation - * - * @access private - * @since 3.0.0 - * @return void - */ - private static function single_activate() { - $notices = get_option( 'ReduxFrameworkPlugin_ACTIVATED_NOTICES', array() ); - $notices[] = __( 'Redux Framework has an embedded demo.', 'redux-framework' ) . ' ' . __( 'Click here to activate the sample config file.', 'redux-framework' ) . ''; - - update_option( 'ReduxFrameworkPlugin_ACTIVATED_NOTICES', $notices ); - } - - /** - * Display admin notices - * - * @access public - * @since 3.0.0 - * @return void - */ - public function admin_notices() { - do_action( 'ReduxFrameworkPlugin_admin_notice' ); - $notices = get_option( 'ReduxFrameworkPlugin_ACTIVATED_NOTICES', '' ); - if ( !empty( $notices ) ) { - foreach ( $notices as $notice ) { - echo '

    ' . $notice . '

    '; - } - - delete_option( 'ReduxFrameworkPlugin_ACTIVATED_NOTICES' ); - } - } - - /** - * Fired for each blog when the plugin is deactivated - * - * @access private - * @since 3.0.0 - * @return void - */ - private static function single_deactivate() { - delete_option( 'ReduxFrameworkPlugin_ACTIVATED_NOTICES' ); - } - - /** - * Turn on or off - * - * @access public - * @since 3.0.0 - * @global string $pagenow The current page being displayed - * @return void - */ - public function options_toggle_check() { - global $pagenow; - - if ( $pagenow == 'plugins.php' && is_admin() && ! empty( $_GET['ReduxFrameworkPlugin'] ) ) { - $url = './plugins.php'; - - if ( $_GET['ReduxFrameworkPlugin'] == 'demo' ) { - if ( $this->options['demo'] == false ) { - $this->options['demo'] = true; - } else { - $this->options['demo'] = false; - } - } - - if ( is_multisite() && is_network_admin() && $this->plugin_network_activated ) { - update_site_option( 'ReduxFrameworkPlugin', $this->options ); - } else { - update_option( 'ReduxFrameworkPlugin', $this->options ); - } - - wp_redirect( $url ); - } - } - - /** - * Add settings action link to plugins page - * - * @access public - * @since 3.0.0 - * @return void - */ - public function add_action_links( $links ) { - // In case we ever want to do this... - return $links; - - /** - * return array_merge( - * array( 'redux_plugin_settings' => '' . __( 'Settings', 'redux-framework' ) . '' ), - * $links - * ); - */ - } - - /** - * Edit plugin metalinks - * - * @access public - * @since 3.0.0 - * - * @param array $links The current array of links - * @param string $file A specific plugin row - * - * @return array The modified array of links - */ - public function plugin_metalinks( $links, $file ) { - if ( strpos( $file, 'redux-framework.php' ) !== false && is_plugin_active( $file ) ) { - - $new_links = array( - '' . __( 'Docs', 'redux-framework' ) . '', - '' . __( 'Repo', 'redux-framework' ) . '', - '' . __( 'Builder', 'redux-framework' ) . '', - '' . __( 'Get Support', 'redux-framework' ) . '', - ); - - if ( ( is_multisite() && $this->plugin_network_activated ) || ! is_network_admin() || ! is_multisite() ) { - if ( $this->options['demo'] ) { - $new_links[3] .= '
    ' . __( 'Deactivate Demo Mode', 'redux-framework' ) . ''; - } else { - $new_links[3] .= '
    ' . __( 'Activate Demo Mode', 'redux-framework' ) . ''; - } - } - - $links = array_merge( $links, $new_links ); - } - - return $links; - } - } - } diff --git a/library/admin/codestyles/.editorconfig b/library/admin/codestyles/.editorconfig deleted file mode 100644 index 36b53360..00000000 --- a/library/admin/codestyles/.editorconfig +++ /dev/null @@ -1,24 +0,0 @@ -# EditorConfig helps developers define and maintain consistent -# coding styles between different editors and IDEs -# editorconfig.org - -root = true - -[*] -end_of_line = lf -charset = utf-8 -indent_style = space -tab_width = 4 -insert_final_newline = true -trim_trailing_whitespace = true - -[*.md] -trim_trailing_whitespace = false -indent_size = 2 - -[*.txt] -trim_trailing_whitespace = false - -[*.json] -indent_size = 2 -insert_final_newline = false \ No newline at end of file diff --git a/library/admin/codestyles/PHPStorm.xml b/library/admin/codestyles/PHPStorm.xml deleted file mode 100644 index 1a107ee7..00000000 --- a/library/admin/codestyles/PHPStorm.xml +++ /dev/null @@ -1,91 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - - - diff --git a/library/admin/codestyles/README.md b/library/admin/codestyles/README.md deleted file mode 100644 index 989d3efe..00000000 --- a/library/admin/codestyles/README.md +++ /dev/null @@ -1 +0,0 @@ -To save on effort, the following code styles have been provided. They are named by the program they correspond to. Please run code formatting through this formats before submitting a pull request. \ No newline at end of file diff --git a/library/admin/composer.json b/library/admin/composer.json deleted file mode 100644 index 3d9335df..00000000 --- a/library/admin/composer.json +++ /dev/null @@ -1,21 +0,0 @@ -{ - "name": "redux-framework/redux-framework", - "version": "3.5.6.1", - "authors": [ - { - "name": "Team Redux" - } - ], - "type": "wordpress-plugin", - "description": "Redux is a simple, truly extensible options framework for WordPress themes and plugins.", - "homepage": "http://reduxframework.com", - "license": "GPL-3.0+", - "keywords": ["settings", "wordpress", "options", "framework", "redux", "customizer", "plugin"], - "support": { - "issues": "https://github.com/reduxframework/redux-framework/issues" - }, - "require" : { - "php" : ">=5.2.0", - "composer/installers": "~1.0" - } -} diff --git a/library/admin/index.php b/library/admin/index.php deleted file mode 100644 index 7e914158..00000000 --- a/library/admin/index.php +++ /dev/null @@ -1,2 +0,0 @@ - - Everyone is permitted to copy and distribute verbatim copies - of this license document, but changing it is not allowed. - - Preamble - - The GNU General Public License is a free, copyleft license for -software and other kinds of works. - - The licenses for most software and other practical works are designed -to take away your freedom to share and change the works. By contrast, -the GNU General Public License is intended to guarantee your freedom to -share and change all versions of a program--to make sure it remains free -software for all its users. We, the Free Software Foundation, use the -GNU General Public License for most of our software; it applies also to -any other work released this way by its authors. You can apply it to -your programs, too. - - When we speak of free software, we are referring to freedom, not -price. Our General Public Licenses are designed to make sure that you -have the freedom to distribute copies of free software (and charge for -them if you wish), that you receive source code or can get it if you -want it, that you can change the software or use pieces of it in new -free programs, and that you know you can do these things. - - To protect your rights, we need to prevent others from denying you -these rights or asking you to surrender the rights. Therefore, you have -certain responsibilities if you distribute copies of the software, or if -you modify it: responsibilities to respect the freedom of others. - - For example, if you distribute copies of such a program, whether -gratis or for a fee, you must pass on to the recipients the same -freedoms that you received. You must make sure that they, too, receive -or can get the source code. And you must show them these terms so they -know their rights. - - Developers that use the GNU GPL protect your rights with two steps: -(1) assert copyright on the software, and (2) offer you this License -giving you legal permission to copy, distribute and/or modify it. - - For the developers' and authors' protection, the GPL clearly explains -that there is no warranty for this free software. For both users' and -authors' sake, the GPL requires that modified versions be marked as -changed, so that their problems will not be attributed erroneously to -authors of previous versions. - - Some devices are designed to deny users access to install or run -modified versions of the software inside them, although the manufacturer -can do so. This is fundamentally incompatible with the aim of -protecting users' freedom to change the software. The systematic -pattern of such abuse occurs in the area of products for individuals to -use, which is precisely where it is most unacceptable. Therefore, we -have designed this version of the GPL to prohibit the practice for those -products. If such problems arise substantially in other domains, we -stand ready to extend this provision to those domains in future versions -of the GPL, as needed to protect the freedom of users. - - Finally, every program is threatened constantly by software patents. -States should not allow patents to restrict development and use of -software on general-purpose computers, but in those that do, we wish to -avoid the special danger that patents applied to a free program could -make it effectively proprietary. To prevent this, the GPL assures that -patents cannot be used to render the program non-free. - - The precise terms and conditions for copying, distribution and -modification follow. - - TERMS AND CONDITIONS - - 0. Definitions. - - "This License" refers to version 3 of the GNU General Public License. - - "Copyright" also means copyright-like laws that apply to other kinds of -works, such as semiconductor masks. - - "The Program" refers to any copyrightable work licensed under this -License. Each licensee is addressed as "you". "Licensees" and -"recipients" may be individuals or organizations. - - To "modify" a work means to copy from or adapt all or part of the work -in a fashion requiring copyright permission, other than the making of an -exact copy. The resulting work is called a "modified version" of the -earlier work or a work "based on" the earlier work. - - A "covered work" means either the unmodified Program or a work based -on the Program. - - To "propagate" a work means to do anything with it that, without -permission, would make you directly or secondarily liable for -infringement under applicable copyright law, except executing it on a -computer or modifying a private copy. Propagation includes copying, -distribution (with or without modification), making available to the -public, and in some countries other activities as well. - - To "convey" a work means any kind of propagation that enables other -parties to make or receive copies. Mere interaction with a user through -a computer network, with no transfer of a copy, is not conveying. - - An interactive user interface displays "Appropriate Legal Notices" -to the extent that it includes a convenient and prominently visible -feature that (1) displays an appropriate copyright notice, and (2) -tells the user that there is no warranty for the work (except to the -extent that warranties are provided), that licensees may convey the -work under this License, and how to view a copy of this License. If -the interface presents a list of user commands or options, such as a -menu, a prominent item in the list meets this criterion. - - 1. Source Code. - - The "source code" for a work means the preferred form of the work -for making modifications to it. "Object code" means any non-source -form of a work. - - A "Standard Interface" means an interface that either is an official -standard defined by a recognized standards body, or, in the case of -interfaces specified for a particular programming language, one that -is widely used among developers working in that language. - - The "System Libraries" of an executable work include anything, other -than the work as a whole, that (a) is included in the normal form of -packaging a Major Component, but which is not part of that Major -Component, and (b) serves only to enable use of the work with that -Major Component, or to implement a Standard Interface for which an -implementation is available to the public in source code form. A -"Major Component", in this context, means a major essential component -(kernel, window system, and so on) of the specific operating system -(if any) on which the executable work runs, or a compiler used to -produce the work, or an object code interpreter used to run it. - - The "Corresponding Source" for a work in object code form means all -the source code needed to generate, install, and (for an executable -work) run the object code and to modify the work, including scripts to -control those activities. However, it does not include the work's -System Libraries, or general-purpose tools or generally available free -programs which are used unmodified in performing those activities but -which are not part of the work. For example, Corresponding Source -includes interface definition files associated with source files for -the work, and the source code for shared libraries and dynamically -linked subprograms that the work is specifically designed to require, -such as by intimate data communication or control flow between those -subprograms and other parts of the work. - - The Corresponding Source need not include anything that users -can regenerate automatically from other parts of the Corresponding -Source. - - The Corresponding Source for a work in source code form is that -same work. - - 2. Basic Permissions. - - All rights granted under this License are granted for the term of -copyright on the Program, and are irrevocable provided the stated -conditions are met. This License explicitly affirms your unlimited -permission to run the unmodified Program. The output from running a -covered work is covered by this License only if the output, given its -content, constitutes a covered work. This License acknowledges your -rights of fair use or other equivalent, as provided by copyright law. - - You may make, run and propagate covered works that you do not -convey, without conditions so long as your license otherwise remains -in force. You may convey covered works to others for the sole purpose -of having them make modifications exclusively for you, or provide you -with facilities for running those works, provided that you comply with -the terms of this License in conveying all material for which you do -not control copyright. Those thus making or running the covered works -for you must do so exclusively on your behalf, under your direction -and control, on terms that prohibit them from making any copies of -your copyrighted material outside their relationship with you. - - Conveying under any other circumstances is permitted solely under -the conditions stated below. Sublicensing is not allowed; section 10 -makes it unnecessary. - - 3. Protecting Users' Legal Rights From Anti-Circumvention Law. - - No covered work shall be deemed part of an effective technological -measure under any applicable law fulfilling obligations under article -11 of the WIPO copyright treaty adopted on 20 December 1996, or -similar laws prohibiting or restricting circumvention of such -measures. - - When you convey a covered work, you waive any legal power to forbid -circumvention of technological measures to the extent such circumvention -is effected by exercising rights under this License with respect to -the covered work, and you disclaim any intention to limit operation or -modification of the work as a means of enforcing, against the work's -users, your or third parties' legal rights to forbid circumvention of -technological measures. - - 4. Conveying Verbatim Copies. - - You may convey verbatim copies of the Program's source code as you -receive it, in any medium, provided that you conspicuously and -appropriately publish on each copy an appropriate copyright notice; -keep intact all notices stating that this License and any -non-permissive terms added in accord with section 7 apply to the code; -keep intact all notices of the absence of any warranty; and give all -recipients a copy of this License along with the Program. - - You may charge any price or no price for each copy that you convey, -and you may offer support or warranty protection for a fee. - - 5. Conveying Modified Source Versions. - - You may convey a work based on the Program, or the modifications to -produce it from the Program, in the form of source code under the -terms of section 4, provided that you also meet all of these conditions: - - a) The work must carry prominent notices stating that you modified - it, and giving a relevant date. - - b) The work must carry prominent notices stating that it is - released under this License and any conditions added under section - 7. This requirement modifies the requirement in section 4 to - "keep intact all notices". - - c) You must license the entire work, as a whole, under this - License to anyone who comes into possession of a copy. This - License will therefore apply, along with any applicable section 7 - additional terms, to the whole of the work, and all its parts, - regardless of how they are packaged. This License gives no - permission to license the work in any other way, but it does not - invalidate such permission if you have separately received it. - - d) If the work has interactive user interfaces, each must display - Appropriate Legal Notices; however, if the Program has interactive - interfaces that do not display Appropriate Legal Notices, your - work need not make them do so. - - A compilation of a covered work with other separate and independent -works, which are not by their nature extensions of the covered work, -and which are not combined with it such as to form a larger program, -in or on a volume of a storage or distribution medium, is called an -"aggregate" if the compilation and its resulting copyright are not -used to limit the access or legal rights of the compilation's users -beyond what the individual works permit. Inclusion of a covered work -in an aggregate does not cause this License to apply to the other -parts of the aggregate. - - 6. Conveying Non-Source Forms. - - You may convey a covered work in object code form under the terms -of sections 4 and 5, provided that you also convey the -machine-readable Corresponding Source under the terms of this License, -in one of these ways: - - a) Convey the object code in, or embodied in, a physical product - (including a physical distribution medium), accompanied by the - Corresponding Source fixed on a durable physical medium - customarily used for software interchange. - - b) Convey the object code in, or embodied in, a physical product - (including a physical distribution medium), accompanied by a - written offer, valid for at least three years and valid for as - long as you offer spare parts or customer support for that product - model, to give anyone who possesses the object code either (1) a - copy of the Corresponding Source for all the software in the - product that is covered by this License, on a durable physical - medium customarily used for software interchange, for a price no - more than your reasonable cost of physically performing this - conveying of source, or (2) access to copy the - Corresponding Source from a network server at no charge. - - c) Convey individual copies of the object code with a copy of the - written offer to provide the Corresponding Source. This - alternative is allowed only occasionally and noncommercially, and - only if you received the object code with such an offer, in accord - with subsection 6b. - - d) Convey the object code by offering access from a designated - place (gratis or for a charge), and offer equivalent access to the - Corresponding Source in the same way through the same place at no - further charge. You need not require recipients to copy the - Corresponding Source along with the object code. If the place to - copy the object code is a network server, the Corresponding Source - may be on a different server (operated by you or a third party) - that supports equivalent copying facilities, provided you maintain - clear directions next to the object code saying where to find the - Corresponding Source. Regardless of what server hosts the - Corresponding Source, you remain obligated to ensure that it is - available for as long as needed to satisfy these requirements. - - e) Convey the object code using peer-to-peer transmission, provided - you inform other peers where the object code and Corresponding - Source of the work are being offered to the general public at no - charge under subsection 6d. - - A separable portion of the object code, whose source code is excluded -from the Corresponding Source as a System Library, need not be -included in conveying the object code work. - - A "User Product" is either (1) a "consumer product", which means any -tangible personal property which is normally used for personal, family, -or household purposes, or (2) anything designed or sold for incorporation -into a dwelling. In determining whether a product is a consumer product, -doubtful cases shall be resolved in favor of coverage. For a particular -product received by a particular user, "normally used" refers to a -typical or common use of that class of product, regardless of the status -of the particular user or of the way in which the particular user -actually uses, or expects or is expected to use, the product. A product -is a consumer product regardless of whether the product has substantial -commercial, industrial or non-consumer uses, unless such uses represent -the only significant mode of use of the product. - - "Installation Information" for a User Product means any methods, -procedures, authorization keys, or other information required to install -and execute modified versions of a covered work in that User Product from -a modified version of its Corresponding Source. The information must -suffice to ensure that the continued functioning of the modified object -code is in no case prevented or interfered with solely because -modification has been made. - - If you convey an object code work under this section in, or with, or -specifically for use in, a User Product, and the conveying occurs as -part of a transaction in which the right of possession and use of the -User Product is transferred to the recipient in perpetuity or for a -fixed term (regardless of how the transaction is characterized), the -Corresponding Source conveyed under this section must be accompanied -by the Installation Information. But this requirement does not apply -if neither you nor any third party retains the ability to install -modified object code on the User Product (for example, the work has -been installed in ROM). - - The requirement to provide Installation Information does not include a -requirement to continue to provide support service, warranty, or updates -for a work that has been modified or installed by the recipient, or for -the User Product in which it has been modified or installed. Access to a -network may be denied when the modification itself materially and -adversely affects the operation of the network or violates the rules and -protocols for communication across the network. - - Corresponding Source conveyed, and Installation Information provided, -in accord with this section must be in a format that is publicly -documented (and with an implementation available to the public in -source code form), and must require no special password or key for -unpacking, reading or copying. - - 7. Additional Terms. - - "Additional permissions" are terms that supplement the terms of this -License by making exceptions from one or more of its conditions. -Additional permissions that are applicable to the entire Program shall -be treated as though they were included in this License, to the extent -that they are valid under applicable law. If additional permissions -apply only to part of the Program, that part may be used separately -under those permissions, but the entire Program remains governed by -this License without regard to the additional permissions. - - When you convey a copy of a covered work, you may at your option -remove any additional permissions from that copy, or from any part of -it. (Additional permissions may be written to require their own -removal in certain cases when you modify the work.) You may place -additional permissions on material, added by you to a covered work, -for which you have or can give appropriate copyright permission. - - Notwithstanding any other provision of this License, for material you -add to a covered work, you may (if authorized by the copyright holders of -that material) supplement the terms of this License with terms: - - a) Disclaiming warranty or limiting liability differently from the - terms of sections 15 and 16 of this License; or - - b) Requiring preservation of specified reasonable legal notices or - author attributions in that material or in the Appropriate Legal - Notices displayed by works containing it; or - - c) Prohibiting misrepresentation of the origin of that material, or - requiring that modified versions of such material be marked in - reasonable ways as different from the original version; or - - d) Limiting the use for publicity purposes of names of licensors or - authors of the material; or - - e) Declining to grant rights under trademark law for use of some - trade names, trademarks, or service marks; or - - f) Requiring indemnification of licensors and authors of that - material by anyone who conveys the material (or modified versions of - it) with contractual assumptions of liability to the recipient, for - any liability that these contractual assumptions directly impose on - those licensors and authors. - - All other non-permissive additional terms are considered "further -restrictions" within the meaning of section 10. If the Program as you -received it, or any part of it, contains a notice stating that it is -governed by this License along with a term that is a further -restriction, you may remove that term. If a license document contains -a further restriction but permits relicensing or conveying under this -License, you may add to a covered work material governed by the terms -of that license document, provided that the further restriction does -not survive such relicensing or conveying. - - If you add terms to a covered work in accord with this section, you -must place, in the relevant source files, a statement of the -additional terms that apply to those files, or a notice indicating -where to find the applicable terms. - - Additional terms, permissive or non-permissive, may be stated in the -form of a separately written license, or stated as exceptions; -the above requirements apply either way. - - 8. Termination. - - You may not propagate or modify a covered work except as expressly -provided under this License. Any attempt otherwise to propagate or -modify it is void, and will automatically terminate your rights under -this License (including any patent licenses granted under the third -paragraph of section 11). - - However, if you cease all violation of this License, then your -license from a particular copyright holder is reinstated (a) -provisionally, unless and until the copyright holder explicitly and -finally terminates your license, and (b) permanently, if the copyright -holder fails to notify you of the violation by some reasonable means -prior to 60 days after the cessation. - - Moreover, your license from a particular copyright holder is -reinstated permanently if the copyright holder notifies you of the -violation by some reasonable means, this is the first time you have -received notice of violation of this License (for any work) from that -copyright holder, and you cure the violation prior to 30 days after -your receipt of the notice. - - Termination of your rights under this section does not terminate the -licenses of parties who have received copies or rights from you under -this License. If your rights have been terminated and not permanently -reinstated, you do not qualify to receive new licenses for the same -material under section 10. - - 9. Acceptance Not Required for Having Copies. - - You are not required to accept this License in order to receive or -run a copy of the Program. Ancillary propagation of a covered work -occurring solely as a consequence of using peer-to-peer transmission -to receive a copy likewise does not require acceptance. However, -nothing other than this License grants you permission to propagate or -modify any covered work. These actions infringe copyright if you do -not accept this License. Therefore, by modifying or propagating a -covered work, you indicate your acceptance of this License to do so. - - 10. Automatic Licensing of Downstream Recipients. - - Each time you convey a covered work, the recipient automatically -receives a license from the original licensors, to run, modify and -propagate that work, subject to this License. You are not responsible -for enforcing compliance by third parties with this License. - - An "entity transaction" is a transaction transferring control of an -organization, or substantially all assets of one, or subdividing an -organization, or merging organizations. If propagation of a covered -work results from an entity transaction, each party to that -transaction who receives a copy of the work also receives whatever -licenses to the work the party's predecessor in interest had or could -give under the previous paragraph, plus a right to possession of the -Corresponding Source of the work from the predecessor in interest, if -the predecessor has it or can get it with reasonable efforts. - - You may not impose any further restrictions on the exercise of the -rights granted or affirmed under this License. For example, you may -not impose a license fee, royalty, or other charge for exercise of -rights granted under this License, and you may not initiate litigation -(including a cross-claim or counterclaim in a lawsuit) alleging that -any patent claim is infringed by making, using, selling, offering for -sale, or importing the Program or any portion of it. - - 11. Patents. - - A "contributor" is a copyright holder who authorizes use under this -License of the Program or a work on which the Program is based. The -work thus licensed is called the contributor's "contributor version". - - A contributor's "essential patent claims" are all patent claims -owned or controlled by the contributor, whether already acquired or -hereafter acquired, that would be infringed by some manner, permitted -by this License, of making, using, or selling its contributor version, -but do not include claims that would be infringed only as a -consequence of further modification of the contributor version. For -purposes of this definition, "control" includes the right to grant -patent sublicenses in a manner consistent with the requirements of -this License. - - Each contributor grants you a non-exclusive, worldwide, royalty-free -patent license under the contributor's essential patent claims, to -make, use, sell, offer for sale, import and otherwise run, modify and -propagate the contents of its contributor version. - - In the following three paragraphs, a "patent license" is any express -agreement or commitment, however denominated, not to enforce a patent -(such as an express permission to practice a patent or covenant not to -sue for patent infringement). To "grant" such a patent license to a -party means to make such an agreement or commitment not to enforce a -patent against the party. - - If you convey a covered work, knowingly relying on a patent license, -and the Corresponding Source of the work is not available for anyone -to copy, free of charge and under the terms of this License, through a -publicly available network server or other readily accessible means, -then you must either (1) cause the Corresponding Source to be so -available, or (2) arrange to deprive yourself of the benefit of the -patent license for this particular work, or (3) arrange, in a manner -consistent with the requirements of this License, to extend the patent -license to downstream recipients. "Knowingly relying" means you have -actual knowledge that, but for the patent license, your conveying the -covered work in a country, or your recipient's use of the covered work -in a country, would infringe one or more identifiable patents in that -country that you have reason to believe are valid. - - If, pursuant to or in connection with a single transaction or -arrangement, you convey, or propagate by procuring conveyance of, a -covered work, and grant a patent license to some of the parties -receiving the covered work authorizing them to use, propagate, modify -or convey a specific copy of the covered work, then the patent license -you grant is automatically extended to all recipients of the covered -work and works based on it. - - A patent license is "discriminatory" if it does not include within -the scope of its coverage, prohibits the exercise of, or is -conditioned on the non-exercise of one or more of the rights that are -specifically granted under this License. You may not convey a covered -work if you are a party to an arrangement with a third party that is -in the business of distributing software, under which you make payment -to the third party based on the extent of your activity of conveying -the work, and under which the third party grants, to any of the -parties who would receive the covered work from you, a discriminatory -patent license (a) in connection with copies of the covered work -conveyed by you (or copies made from those copies), or (b) primarily -for and in connection with specific products or compilations that -contain the covered work, unless you entered into that arrangement, -or that patent license was granted, prior to 28 March 2007. - - Nothing in this License shall be construed as excluding or limiting -any implied license or other defenses to infringement that may -otherwise be available to you under applicable patent law. - - 12. No Surrender of Others' Freedom. - - If conditions are imposed on you (whether by court order, agreement or -otherwise) that contradict the conditions of this License, they do not -excuse you from the conditions of this License. If you cannot convey a -covered work so as to satisfy simultaneously your obligations under this -License and any other pertinent obligations, then as a consequence you may -not convey it at all. For example, if you agree to terms that obligate you -to collect a royalty for further conveying from those to whom you convey -the Program, the only way you could satisfy both those terms and this -License would be to refrain entirely from conveying the Program. - - 13. Use with the GNU Affero General Public License. - - Notwithstanding any other provision of this License, you have -permission to link or combine any covered work with a work licensed -under version 3 of the GNU Affero General Public License into a single -combined work, and to convey the resulting work. The terms of this -License will continue to apply to the part which is the covered work, -but the special requirements of the GNU Affero General Public License, -section 13, concerning interaction through a network will apply to the -combination as such. - - 14. Revised Versions of this License. - - The Free Software Foundation may publish revised and/or new versions of -the GNU General Public License from time to time. Such new versions will -be similar in spirit to the present version, but may differ in detail to -address new problems or concerns. - - Each version is given a distinguishing version number. If the -Program specifies that a certain numbered version of the GNU General -Public License "or any later version" applies to it, you have the -option of following the terms and conditions either of that numbered -version or of any later version published by the Free Software -Foundation. If the Program does not specify a version number of the -GNU General Public License, you may choose any version ever published -by the Free Software Foundation. - - If the Program specifies that a proxy can decide which future -versions of the GNU General Public License can be used, that proxy's -public statement of acceptance of a version permanently authorizes you -to choose that version for the Program. - - Later license versions may give you additional or different -permissions. However, no additional obligations are imposed on any -author or copyright holder as a result of your choosing to follow a -later version. - - 15. Disclaimer of Warranty. - - THERE IS NO WARRANTY FOR THE PROGRAM, TO THE EXTENT PERMITTED BY -APPLICABLE LAW. EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT -HOLDERS AND/OR OTHER PARTIES PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY -OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, -THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR -PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE PROGRAM -IS WITH YOU. SHOULD THE PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF -ALL NECESSARY SERVICING, REPAIR OR CORRECTION. - - 16. Limitation of Liability. - - IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING -WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MODIFIES AND/OR CONVEYS -THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY -GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE -USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED TO LOSS OF -DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD -PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER PROGRAMS), -EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF -SUCH DAMAGES. - - 17. Interpretation of Sections 15 and 16. - - If the disclaimer of warranty and limitation of liability provided -above cannot be given local legal effect according to their terms, -reviewing courts shall apply local law that most closely approximates -an absolute waiver of all civil liability in connection with the -Program, unless a warranty or assumption of liability accompanies a -copy of the Program in return for a fee. - - END OF TERMS AND CONDITIONS - - How to Apply These Terms to Your New Programs - - If you develop a new program, and you want it to be of the greatest -possible use to the public, the best way to achieve this is to make it -free software which everyone can redistribute and change under these terms. - - To do so, attach the following notices to the program. It is safest -to attach them to the start of each source file to most effectively -state the exclusion of warranty; and each file should have at least -the "copyright" line and a pointer to where the full notice is found. - - - Copyright (C) - - This program is free software: you can redistribute it and/or modify - it under the terms of the GNU General Public License as published by - the Free Software Foundation, either version 3 of the License, or - (at your option) any later version. - - This program is distributed in the hope that it will be useful, - but WITHOUT ANY WARRANTY; without even the implied warranty of - MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - GNU General Public License for more details. - - You should have received a copy of the GNU General Public License - along with this program. If not, see . - -Also add information on how to contact you by electronic and paper mail. - - If the program does terminal interaction, make it output a short -notice like this when it starts in an interactive mode: - - Copyright (C) - This program comes with ABSOLUTELY NO WARRANTY; for details type `show w'. - This is free software, and you are welcome to redistribute it - under certain conditions; type `show c' for details. - -The hypothetical commands `show w' and `show c' should show the appropriate -parts of the General Public License. Of course, your program's commands -might be different; for a GUI interface, you would use an "about box". - - You should also get your employer (if you work as a programmer) or school, -if any, to sign a "copyright disclaimer" for the program, if necessary. -For more information on this, and how to apply and follow the GNU GPL, see -. - - The GNU General Public License does not permit incorporating your program -into proprietary programs. If your program is a subroutine library, you -may consider it more useful to permit linking proprietary applications with -the library. If this is what you want to do, use the GNU Lesser General -Public License instead of this License. But first, please read -. - -=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-= - -The source code for any program binaries or compressed scripts that are -included with ReduxFramework can be freely obtained at the following URL: - - https://github.com/ReduxFramework/ReduxFramework - \ No newline at end of file diff --git a/library/admin/package.json b/library/admin/package.json deleted file mode 100644 index 9eff4f11..00000000 --- a/library/admin/package.json +++ /dev/null @@ -1,50 +0,0 @@ -{ - "name": "redux-framework", - "version": "3.5.4", - "title": "ReduxFramework", - "description": "Redux is a simple, truly extensible options framework for WordPress themes and plugins.", - "main": "Gruntfile.js", - "directories": { - "doc": "docs", - "test": "tests" - }, - "repository": { - "type": "git", - "url": "https://github.com/ReduxFramework/ReduxFramework.git" - }, - "bugs": { - "url": "https://github.com/ReduxFramework/ReduxFramework/issues" - }, - "author": "Redux Framework Team", - "license": "GPLv3+", - "homepage": "http://reduxframework.com", - "devDependencies": { - "compass-options": "^0.1.1", - "grunt": "^0.4.5", - "grunt-checktextdomain": "^0.1.1", - "grunt-contrib-compass": "^1.0.1", - "grunt-contrib-concat": "^0.5.0", - "grunt-contrib-copy": "^0.5.0", - "grunt-contrib-cssmin": "^0.11.0", - "grunt-contrib-jshint": "^0.10.0", - "grunt-contrib-less": "^0.11.4", - "grunt-contrib-qunit": "^0.5.2", - "grunt-contrib-sass": "^0.8.1", - "grunt-contrib-uglify": "^0.5.1", - "grunt-contrib-watch": "^0.6.1", - "grunt-gh-pages": "^0.9.1", - "grunt-phpdocumentor": "^0.4.1", - "grunt-phplint": "^0.0.5", - "grunt-potomo": "^3.0.0", - "grunt-recess": "^1.0.0", - "grunt-scss-lint": "^0.3.4", - "grunt-shell": "^1.1.1", - "grunt-wp-i18n": "^0.4.8", - "recess": "^1.1.9", - "shelljs": "^0.3.0" - }, - "engines": { - "node": ">=0.10.0", - "npm": ">=1.4.0" - } -} diff --git a/library/admin/phpunit.xml b/library/admin/phpunit.xml deleted file mode 100644 index 44f0fdb6..00000000 --- a/library/admin/phpunit.xml +++ /dev/null @@ -1,14 +0,0 @@ - - - - ./tests/ - - - diff --git a/library/admin/redux-framework.php b/library/admin/redux-framework.php deleted file mode 100644 index b837c27c..00000000 --- a/library/admin/redux-framework.php +++ /dev/null @@ -1,50 +0,0 @@ - - * @author Kevin Provance - * @author Daniel J Griffiths - * @license GNU General Public License, version 3 - * @copyright 2012-2015 Redux Framework - */ - -// Exit if accessed directly -if( !defined( 'ABSPATH' ) ) { - die; -} - -// Require the main plugin class -require_once plugin_dir_path( __FILE__ ) . 'class.redux-plugin.php'; - -// Register hooks that are fired when the plugin is activated and deactivated, respectively. -register_activation_hook( __FILE__, array( 'ReduxFrameworkPlugin', 'activate' ) ); -register_deactivation_hook( __FILE__, array( 'ReduxFrameworkPlugin', 'deactivate' ) ); - -// Get plugin instance -//add_action( 'plugins_loaded', array( 'ReduxFrameworkPlugin', 'instance' ) ); - -// The above line prevents ReduxFramework from instancing until all plugins have loaded. -// While this does not matter for themes, any plugin using Redux will not load properly. -// Waiting until all plugins have been loaded prevents the ReduxFramework class from -// being created, and fails the !class_exists('ReduxFramework') check in the sample_config.php, -// and thus prevents any plugin using Redux from loading their config file. -ReduxFrameworkPlugin::instance(); diff --git a/library/admin/tests/bootstrap.php b/library/admin/tests/bootstrap.php deleted file mode 100644 index 374cf514..00000000 --- a/library/admin/tests/bootstrap.php +++ /dev/null @@ -1,31 +0,0 @@ - array( 'tivwp-dm/tivwp-dm.php' ), -); - -// fire up test suite -require_once $_tests_dir . 'bootstrap.php'; - -// include unit test base class -//require_once dirname( __FILE__ ) . '/framework/class-wpseo-unit-test-case.php'; diff --git a/library/admin/tests/includes/class-tivwp-dm-controller.php b/library/admin/tests/includes/class-tivwp-dm-controller.php deleted file mode 100644 index 12a28512..00000000 --- a/library/admin/tests/includes/class-tivwp-dm-controller.php +++ /dev/null @@ -1,165 +0,0 @@ - - * @author Gary Jones - * @link https://github.com/thomasgriffin/TGM-Plugin-Activation - */ - require_once dirname(__FILE__) . '/../vendor/class-tgm-plugin-activation.php'; - } - - /** - * This happens on - * @wp-hook init - * @see TGM_Plugin_Activation::init - * @see TIVWP_DM::action_tgmpa_register - */ - add_action('tgmpa_register', array( - 'TIVWP_DM', - 'action_tgmpa_register' - )); - } - - /** - * Setup admin area menus to bulk switch development plugins on/off - * @see TIVWP_DM::turn_output_buffering - * @see TIVWP_DM::action_admin_menu - */ - private static function _setup_admin_interface() { - - add_action('admin_init', array( - 'TIVWP_DM', - 'turn_output_buffering' - )); - - add_action('admin_menu', array( - 'TIVWP_DM', - 'action_admin_menu' - )); - } - - /** - * Setup automatic plugins on/off switching depending on the defined TIVWP_DM_AUTO constant - * @see TIVWP_DM::activate_all_development_plugins - * @see TIVWP_DM::deactivate_all_development_plugins - */ - private static function _setup_automatic_switch() { - - if (!defined('TIVWP_DM_AUTO')) { - return; - } - - $action = TIVWP_DM_AUTO; - - /** - * If there is no callable method corresponding to the TIVWP_DM_AUTO set, - * notify admin and set a fallback action - */ - if (!is_callable(array( - 'TIVWP_DM', - "{$action}_all_development_plugins" - )) - ) { - - TIVWP_DM_Notices::add(sprintf(__('Unknown action "%1$s" specified for %2$s', 'tivwp-dm'), $action, 'TIVWP_DM_AUTO'), TIVWP_DM_Notices::WITH_TRIGGER_ERROR - ); - - $action = TIVWP_DM::ACTION_DEACTIVATE; - - TIVWP_DM_Notices::add(sprintf(__('The unknown action has been replaced with "%s"', 'tivwp-dm'), $action), TIVWP_DM_Notices::WITH_TRIGGER_ERROR); - } - - /** - * Silently (de)activate all development plugins - * @todo admin bar on front is shown before this, so it will be updated only on the next screen refresh - */ - add_action('init', array( - 'TIVWP_DM', - "{$action}_all_development_plugins" - ), 20); - - /** - * Enqueue admin notice about the action performed - */ - TIVWP_DM_Notices::add(sprintf(__('Automatic action performed: "%s"', 'tivwp-dm'), $action, TIVWP_DM_Notices::WITHOUT_TRIGGER_ERROR)); - } - -} - -// class - -# --- EOF diff --git a/library/admin/tests/includes/class-tivwp-dm-notices.php b/library/admin/tests/includes/class-tivwp-dm-notices.php deleted file mode 100644 index 3dae9314..00000000 --- a/library/admin/tests/includes/class-tivwp-dm-notices.php +++ /dev/null @@ -1,82 +0,0 @@ -

    '; - echo self::NOTICE_LABEL . ':'; - foreach (self::$_notices as $notice) { - echo '
    ' . esc_html($notice); - } - echo '

    '; - } - -} - -//class - -# --- EOF diff --git a/library/admin/tests/includes/class-tivwp-dm.php b/library/admin/tests/includes/class-tivwp-dm.php deleted file mode 100644 index 016ac61f..00000000 --- a/library/admin/tests/includes/class-tivwp-dm.php +++ /dev/null @@ -1,234 +0,0 @@ - 'Debug Bar', - 'slug' => 'debug-bar', - 'required' => false, - ), - array( - 'name' => 'Debug Bar Console', - 'slug' => 'debug-bar-console', - 'required' => false, - ), - array( - 'name' => 'Kint Debugger', - 'slug' => 'kint-debugger', - 'required' => false, - ), - array( - 'name' => 'Query Monitor', - 'slug' => 'query-monitor', - 'required' => false, - ), - ); - - /** - * Load the default plugin list into the working one, with filter. - */ - public static function load_plugin_list() { - self::$development_plugins = apply_filters('tivwp_dm_plugin_list', self::$_default_development_plugins); - } - - /** - * Hooked methods - */ - - /** - * Load translations - */ - public static function action_init_load_plugin_textdomain() { - /** - * We are in the "includes" sub-folder. Therefore, need this "funny" construction to go up. - * @todo Save plugin folder somewhere else and use it here - */ - $folder_i18n = dirname(dirname(plugin_basename(__FILE__))) . '/languages'; - load_plugin_textdomain('tivwp-dm', false, $folder_i18n); - } - - /** - * Prompt to install required and recommended plugins - * @wp-hook tgmpa_register - */ - public static function action_tgmpa_register() { - tgmpa(self::$development_plugins); - } - - /** - * Turn on output buffering for wp_redirect to work - * @wp-hook admin_init - */ - public static function turn_output_buffering() { - if (isset($GLOBALS['plugin_page']) && in_array($GLOBALS['plugin_page'], array( - self::MENU_SLUG_ACTIVATE, - self::MENU_SLUG_DEACTIVATE, - )) - ) { - ob_start(); - } - } - - /** - * Setup administrator menu options - * @wp-hook admin_menu - */ - public static function action_admin_menu() { - - add_plugins_page( - '', __('Activate Development Plugins', 'tivwp-dm'), self::MIN_CAPABILITY, self::MENU_SLUG_ACTIVATE, array( - __CLASS__, - 'menu_callback_activate' - ) - ); - - add_plugins_page( - '', __('Deactivate Development Plugins', 'tivwp-dm'), self::MIN_CAPABILITY, self::MENU_SLUG_DEACTIVATE, array( - __CLASS__, - 'menu_callback_deactivate' - ) - ); - } - - /** - * Service method: protect from non-authorized users - */ - private static function _die_if_not_authorized() { - if (!current_user_can(self::MIN_CAPABILITY)) { - wp_die(__('You do not have sufficient permissions to access this page.', 'tivwp-dm')); - } - } - - /** - * Activate all development plugins and redirect to the list of active plugins - * activate-multi=true is used to display the "Selected plugins activated" message - */ - public static function menu_callback_activate() { - self::_die_if_not_authorized(); - self::activate_all_development_plugins(); - wp_redirect(self_admin_url('plugins.php?plugin_status=active&activate-multi=true')); - exit; - } - - /** - * Deactivate all development plugins and redirect to the list of inactive plugins - * deactivate-multi=true is used to display the "Selected plugins deactivated" message - */ - public static function menu_callback_deactivate() { - self::_die_if_not_authorized(); - self::deactivate_all_development_plugins(); - wp_redirect(self_admin_url('plugins.php?plugin_status=inactive&deactivate-multi=true')); - exit; - } - - /** - * Public interface to the _switch_all_development_plugins method - */ - public static function activate_all_development_plugins() { - self::_switch_all_development_plugins(self::ACTION_ACTIVATE); - } - - /** - * Public interface to the _switch_all_development_plugins method - */ - public static function deactivate_all_development_plugins() { - self::_switch_all_development_plugins(self::ACTION_DEACTIVATE); - } - - /** - * The $development_plugins array has only plugin slugs, and not the path to the plugin file, - * needed by activation/deactivation methods. - * Therefore, we build a list of plugins in the form $slug => $plugin - * @example - * $all_plugins = array( - * 'query-monitor' => 'query-monitor/query-monitor.php', - * 'debug-bar' => 'debug-bar/debug-bar.php', - * 'woocommerce' => 'woocommerce/woocommerce.php' - * ); - * and then we make the array of the values, keeping only those that are in the $development_plugins - * @example - * $plugins = array( - * 'query-monitor/query-monitor.php', - * 'debug-bar/debug-bar.php', - * ); - * @return array - */ - private static function _get_plugins() { - /** - * When on front, the WordPress Plugin Administration API is not available by default - */ - if (!function_exists('get_plugins')) { - /** @noinspection PhpIncludeInspection */ - require_once ABSPATH . 'wp-admin/includes/plugin.php'; - } - - $all_plugins = array(); - foreach (array_keys(get_plugins()) as $plugin) { - $all_plugins[dirname($plugin)] = $plugin; - } - - $plugins = array(); - foreach (self::$development_plugins as $plugin_info) { - if (!empty($all_plugins[$plugin_info['slug']])) { - $plugins[] = $all_plugins[$plugin_info['slug']]; - } - } - return $plugins; - } - - /** - * Pass the list of development plugins to the (de)activation function. - * @param string $action Activate or Deactivate - */ - private static function _switch_all_development_plugins($action = self::ACTION_ACTIVATE) { - - $plugins = self::_get_plugins(); - $redirect = ''; - $network_wide = false; - $silent = false; - switch ($action) { - case self::ACTION_ACTIVATE: - activate_plugins($plugins, $redirect, $network_wide, $silent); - break; - case self::ACTION_DEACTIVATE: - deactivate_plugins($plugins, $silent, $network_wide); - break; - } - } - -} - -# --- EOF diff --git a/library/admin/tests/test-sample.php b/library/admin/tests/test-sample.php deleted file mode 100644 index 1a23460d..00000000 --- a/library/admin/tests/test-sample.php +++ /dev/null @@ -1,10 +0,0 @@ -assertTrue( true ); - } -} - diff --git a/library/admin/tests/tivwp-dm.php b/library/admin/tests/tivwp-dm.php deleted file mode 100644 index 7ae8a867..00000000 --- a/library/admin/tests/tivwp-dm.php +++ /dev/null @@ -1,79 +0,0 @@ - - * define( 'TIVWP_DM_NETWORK_ACTIVATION_ALLOWED', true ); - * - */ -if (!( defined('TIVWP_DM_NETWORK_ACTIVATION_ALLOWED') && TIVWP_DM_NETWORK_ACTIVATION_ALLOWED )) { - register_activation_hook(__FILE__, 'tivwp_dm_disable_network_activation'); -} - - -/** - * Launch the Controller only after plugins_loaded, so we can do necessary validation - * @see TIVWP_DM_Controller::construct - */ -require_once dirname(__FILE__) . '/includes/class-tivwp-dm-controller.php'; -add_action('plugins_loaded', array( - 'TIVWP_DM_Controller', - 'construct' - ) -); - -# --- EOF diff --git a/library/admin/uninstall.php b/library/admin/uninstall.php deleted file mode 100644 index 097f175f..00000000 --- a/library/admin/uninstall.php +++ /dev/null @@ -1,16 +0,0 @@ - - * @since 3.0.0 - */ - - -// If uninstall, not called from WordPress, then exit -if( !defined( 'WP_UNINSTALL_PLUGIN' ) ) { - exit; -} - -// TODO: Define uninstall functionality here diff --git a/library/admin/wpml-config.xml b/library/admin/wpml-config.xml deleted file mode 100644 index 54f5786f..00000000 --- a/library/admin/wpml-config.xml +++ /dev/null @@ -1,7 +0,0 @@ - - - - - - - \ No newline at end of file diff --git a/library/option-config.php b/library/option-config.php index 8ff8490a..5423dbea 100755 --- a/library/option-config.php +++ b/library/option-config.php @@ -1285,6 +1285,29 @@ public function setSections() { 'desc' => __('Turn breadcrumbs on or off (site-wide)', 'brew-framework'), 'default' => 1, ), + array( + 'id' => 'general-link-color', + 'type' => 'link_color', + 'title' => __('Link Color ', 'brew-framework'), + 'output' => array('a') + ), + array( + 'id' => 'general-text-color', + 'type' => 'color', + 'title' => __('Text Color', 'brew-framework'), + 'validate' => 'color', + 'output' => array( + 'color' => 'p') + ), + array( + 'id' => 'general-headings-color', + 'type' => 'color', + 'title' => __('Heading Color', 'brew-framework'), + 'validate' => 'color', + 'output' => array( + 'color' => 'h1.single-title.entry-title > a, h1,h1, h2, h3, h4, h5, h6') + ), + array ( 'id' => 'author-ops', 'type' => 'section',