: str_replace(): Passing null to parameter #2 ($replace) of type array|string is deprecated in
var CssSelectorGenerator, root,
indexOf = [].indexOf || function (item) {
for (var i = 0, l = this.length; i < l; i++) {
if (i in this && this[i] === item) return i;
CssSelectorGenerator = (function () {
CssSelectorGenerator.prototype.default_options = {
selectors: ['id', 'class', 'tag', 'nthchild']
function CssSelectorGenerator(options) {
this.setOptions(this.default_options);
this.setOptions(options);
CssSelectorGenerator.prototype.setOptions = function (options) {
if (this.default_options.hasOwnProperty(key)) {
results.push(this.options[key] = val);
CssSelectorGenerator.prototype.isElement = function (element) {
return !!((element != null ? element.nodeType : void 0) === 1);
CssSelectorGenerator.prototype.getParents = function (element) {
var current_element, result;
if (this.isElement(element)) {
current_element = element;
while (this.isElement(current_element)) {
result.push(current_element);
current_element = current_element.parentNode;
CssSelectorGenerator.prototype.getTagSelector = function (element) {
return this.sanitizeItem(element.tagName.toLowerCase());
CssSelectorGenerator.prototype.sanitizeItem = function (item) {
characters = (item.split('')).map(function (character) {
return "\\" + (':'.charCodeAt(0).toString(16).toUpperCase()) + " ";
} else if (/[ !"#$%&'()*+,.\/;<=>?@\[\\\]^`{|}~]/.test(character)) {
return escape(character).replace(/\%/g, '\\');
return characters.join('');
CssSelectorGenerator.prototype.getIdSelector = function (element) {
id = element.getAttribute('id');
if ((id != null) && (id !== '') && !(/\s/.exec(id)) && !(/^\d/.exec(id))) {
sanitized_id = "#" + (this.sanitizeItem(id));
if (element.ownerDocument.querySelectorAll(sanitized_id).length === 1) {
CssSelectorGenerator.prototype.getClassSelectors = function (element) {
var class_string, item, result;
class_string = element.getAttribute('class');
if (class_string != null) {
class_string = class_string.replace(/\s+/g, ' ');
class_string = class_string.replace(/^\s|\s$/g, '');
if (class_string !== '') {
var k, len, ref, results;
ref = class_string.split(/\s+/);
for (k = 0, len = ref.length; k < len; k++) {
results.push("." + (this.sanitizeItem(item)));
CssSelectorGenerator.prototype.getAttributeSelectors = function (element) {
var attribute, blacklist, k, len, ref, ref1, result;
blacklist = ['id', 'class'];
ref = element.attributes;
for (k = 0, len = ref.length; k < len; k++) {
if (ref1 = attribute.nodeName, indexOf.call(blacklist, ref1) < 0) {
result.push("[" + attribute.nodeName + "=" + attribute.nodeValue + "]");
CssSelectorGenerator.prototype.getNthChildSelector = function (element) {
var counter, k, len, parent_element, sibling, siblings;
parent_element = element.parentNode;
if (parent_element != null) {
siblings = parent_element.childNodes;
for (k = 0, len = siblings.length; k < len; k++) {
if (this.isElement(sibling)) {
if (sibling === element) {
return ":nth-child(" + counter + ")";
CssSelectorGenerator.prototype.testSelector = function (element, selector) {
if ((selector != null) && selector !== '') {
result = element.ownerDocument.querySelectorAll(selector);
if (result.length === 1 && result[0] === element) {
CssSelectorGenerator.prototype.getAllSelectors = function (element) {
if (indexOf.call(this.options.selectors, 'tag') >= 0) {
result.t = this.getTagSelector(element);
if (indexOf.call(this.options.selectors, 'id') >= 0) {
result.i = this.getIdSelector(element);
if (indexOf.call(this.options.selectors, 'class') >= 0) {
result.c = this.getClassSelectors(element);
if (indexOf.call(this.options.selectors, 'attribute') >= 0) {
result.a = this.getAttributeSelectors(element);
if (indexOf.call(this.options.selectors, 'nthchild') >= 0) {
result.n = this.getNthChildSelector(element);
CssSelectorGenerator.prototype.testUniqueness = function (element, selector) {
var found_elements, parent;
parent = element.parentNode;
found_elements = parent.querySelectorAll(selector);
return found_elements.length === 1 && found_elements[0] === element;
CssSelectorGenerator.prototype.testCombinations = function (element, items, tag) {
var item, k, l, len, len1, ref, ref1;
ref = this.getCombinations(items);
for (k = 0, len = ref.length; k < len; k++) {
if (this.testUniqueness(element, item)) {
ref1 = items.map(function (item) {
for (l = 0, len1 = ref1.length; l < len1; l++) {
if (this.testUniqueness(element, item)) {
CssSelectorGenerator.prototype.getUniqueSelector = function (element) {
var found_selector, k, len, ref, selector_type, selectors;
selectors = this.getAllSelectors(element);
ref = this.options.selectors;
for (k = 0, len = ref.length; k < len; k++) {
if (selectors.i != null) {
if (selectors.t != null) {
if (this.testUniqueness(element, selectors.t)) {
if ((selectors.c != null) && selectors.c.length !== 0) {
found_selector = this.testCombinations(element, selectors.c, selectors.t);
if ((selectors.a != null) && selectors.a.length !== 0) {
found_selector = this.testCombinations(element, selectors.a, selectors.t);
if (selectors.n != null) {
CssSelectorGenerator.prototype.getSelector = function (element) {
var all_selectors, item, k, l, len, len1, parents, result, selector, selectors;
parents = this.getParents(element);
for (k = 0, len = parents.length; k < len; k++) {
selector = this.getUniqueSelector(item);
all_selectors.push(selector);
for (l = 0, len1 = all_selectors.length; l < len1; l++) {
result = selectors.join(' > ');
if (this.testSelector(element, result)) {
CssSelectorGenerator.prototype.getCombinations = function (items) {
var i, j, k, l, ref, ref1, result;
for (i = k = 0, ref = items.length - 1; 0 <= ref ? k <= ref : k >= ref; i = 0 <= ref ? ++k : --k) {
for (j = l = 0, ref1 = result.length - 1; 0 <= ref1 ? l <= ref1 : l >= ref1; j = 0 <= ref1 ? ++l : --l) {
result.push(result[j].concat(items[i]));
result = result.sort(function (a, b) {
return a.length - b.length;
result = result.map(function (item) {
return CssSelectorGenerator;
if (typeof define !== "undefined" && define !== null ? define.amd : void 0) {
return CssSelectorGenerator;
root = typeof exports !== "undefined" && exports !== null ? exports : this;
root.CssSelectorGenerator = CssSelectorGenerator;
var selector_generator = new CssSelectorGenerator;
var pumAdminBarText = pumAdminBarText || {
instructions: 'After clicking ok, click the element you want a selector for.',
$(document).on('click', '#wp-admin-bar-pum-get-selector', function (event) {
alert(pumAdminBarText.instructions);
$(document).one('click', function (event) {
// get reference to the element user clicked on
var element = event.target,
// get unique CSS selector for that element
selector = selector_generator.getSelector(element);
alert( pumAdminBarText.results + ": " + selector);