搞定|创客贴小助手。站内其它版本年久失修,佛系修复。点左上角“去除水印”然后自行截图或点击右上角下载(需手动开启)。
- // ==UserScript==
- // @name gaodingWatermark
- // @version 0.0.0.4
- // @description 搞定|创客贴小助手。站内其它版本年久失修,佛系修复。点左上角“去除水印”然后自行截图或点击右上角下载(需手动开启)。
- // @author pythonk
- // @icon https://st-gdx.dancf.com/assets/20190910-143541-210a.png
- // @icon https://dynamic-image.bear20.com/640x267/uploadImages/2020/289/34/9DTKT3Y2XR06.jpg
- // @match *://*.gaoding.com/design?id=*
- // @match *://*.chuangkit.com/odyssey/design?*
- // @match *://*.chuangkit.com/design*
- // @match https://*.818ps.com/*
- // @match https://www.eqxiu.com/*
- // @match https://bigesj.com/*
- // @require http://cdn.staticfile.org/jquery/1.8.3/jquery.min.js
- // @require https://unpkg.com/sweetalert2@10.16.6/dist/sweetalert2.min.js
- // @resource swalStyle https://unpkg.com/sweetalert2@10.16.6/dist/sweetalert2.min.css
- //
- // @grant unsafeWindow
- // @grant GM_openInTab
- // @grant GM_setValue
- // @grant GM_getValue
- // @grant GM_registerMenuCommand
- // @grant GM_getResourceText
- //
- // @run-at document-idle
- // @namespace https://greatest.deepsurf.us/zh-CN/users/184803-sevensky
- // ==/UserScript==
- // @re quire https://cdn.bootcss.com/jquery/3.3.1/jquery.min.js
- /*
- *
- @run-at
- 定义脚本被注入的时刻。
- 与其他脚本处理程序相反, @run-at 定义了脚本想要运行的第一个可能时刻。这意味着可能会发生,使用 @require 标签的脚本可能会在文档加载后执行,导致获取所需脚本需要很长时间。无论如何,在给定注入时刻之后发生的所有 DOMNodeInserted 和 DOMContentLoaded 事件都被缓存并在注入时传递给脚本。
- 总共四种时刻
- @run-at document-start 脚本将尽快注入。
- @run-at document-body 如果 body 元素存在,脚本将被注入。
- @run-at document-end 该脚本将在调度 DOMContentLoaded 事件时或之后注入。
- @run-at document-idle 该脚本将在调度 DOMContentLoaded 事件后注入。如果没有给出@run-at 标签,这是默认值。
- @run-at context-menu 如果在浏览器上下文菜单中单击该脚本(仅限基于 Chrome 的桌面浏览器),则会注入该脚本。注意:如果使用此值,所有@include和@exclude语句都将被忽略,但将来可能会更改。
- */
- (function () {
- 'use strict';
- let util = {
- getValue(name) { return GM_getValue(name); }, setValue(name, value) { GM_setValue(name, value); },
- include(str, arr) {
- str = str.replace(/[-_]/ig, '');
- for (let i = 0, l = arr.length; i < l; i++) {
- let val = arr[i];
- if (val !== '' && str.toLowerCase().indexOf(val.toLowerCase()) > -1) {
- return true;
- }
- }
- return false;
- },
- addStyle(id, tag, css) {
- tag = tag || 'style';
- let doc = document, styleDom = doc.getElementById(id);
- if (styleDom) return;
- let style = doc.createElement(tag);
- style.rel = 'stylesheet';
- style.id = id;
- tag === 'style' ? style.innerHTML = css : style.href = css;
- doc.head.appendChild(style);
- }
- };
- let main = {
- initValue() {
- let value = [{
- name: 'zoom_links',
- value: false
- },{
- name: 'enable_pdfprint',
- value: true
- }];
- value.forEach((v) => {
- util.getValue(v.name) === undefined && util.setValue(v.name, v.value);
- });
- },
- registerMenuCommand() {
- GM_registerMenuCommand('⚙️ 设置', () => {
- //alert('sd');
- let dom = `<div style="font-size: 1em;">
- <label class="instant-setting-label">PDF打印开关<input type="checkbox" id="S-2" ${util.getValue('enable_pdfprint') ? 'checked' : ''} class="instant-setting-checkbox"></label>
- <label class="instant-setting-label">缩放悬浮按钮<input type="checkbox" id="S-1" ${util.getValue('zoom_links') ? 'checked' : ''} class="instant-setting-checkbox"></label>
- </div>`;
- Swal.fire({
- title: '设置',
- html: dom,
- showCloseButton: true,
- confirmButtonText: '保存',
- footer: '<div style="text-align: center;font-size: 1em;"><a href="https://greatest.deepsurf.us/scripts/441367-gaodingwatermark/code/gaodingWatermark.user.js">检查更新</a><svg viewBox="0 0 1024 1024" xmlns="http://www.w3.org/2000/svg" width="14" height="14"><path d="M445.956 138.812L240.916 493.9c-11.329 19.528-12.066 44.214 0 65.123 12.067 20.909 33.898 32.607 56.465 32.607h89.716v275.044c0 31.963 25.976 57.938 57.938 57.938h134.022c32.055 0 57.938-25.975 57.938-57.938V591.63h83.453c24.685 0 48.634-12.803 61.806-35.739 13.172-22.844 12.343-50.016 0-71.386l-199.42-345.693c-13.633-23.58-39.24-39.516-68.44-39.516-29.198 0-54.897 15.935-68.438 39.516z" fill="#d81e06"/></svg></div>',
- customClass: {
- popup: 'instant-popup',
- },
- }).then((res) => {
- if (res.isConfirmed) {
- history.go(0);
- }
- });
- document.getElementById('S-1').addEventListener('change', (e) => {
- util.setValue('zoom_links', e.currentTarget.checked);
- });
- document.getElementById('S-2').addEventListener('change', (e) => {
- util.setValue('enable_pdfprint', e.currentTarget.checked);
- });
- });
- },
- addPluginStyle() {
- let style = `
- .instant-popup { font-size: 14px !important; }
- .instant-setting-label { display: flex;align-items: center;justify-content: space-between;padding-top: 15px; }
- .instant-setting-label-col { display: flex;align-items: flex-start;;padding-top: 15px;flex-direction:column }
- .instant-setting-checkbox { width: 16px;height: 16px; }
- .instant-setting-textarea { width: 100%; margin: 14px 0 0; height: 60px; resize: none; border: 1px solid #bbb; box-sizing: border-box; padding: 5px 10px; border-radius: 5px; color: #666; line-height: 1.2; }
- .instant-setting-input { border: 1px solid #bbb; box-sizing: border-box; padding: 5px 10px; border-radius: 5px; width: 100px}
- @keyframes instantAnminate { from { opacity: 1; } 50% { opacity: 0.4 } to { opacity: 0.9; }}
- .link-instanted { animation: instantAnminate 0.6s 1; animation-fill-mode:forwards }
- .link-instanted * { animation: instantAnminate 0.6s 1; animation-fill-mode:forwards }
- `;
- if (document.head) {
- util.addStyle('swal-pub-style', 'style', GM_getResourceText('swalStyle'));
- util.addStyle('instant-style', 'style', style);
- }
- const headObserver = new MutationObserver(() => {
- util.addStyle('swal-pub-style', 'style', GM_getResourceText('swalStyle'));
- util.addStyle('instant-style', 'style', style);
- });
- headObserver.observe(document.head, {childList: true, subtree: true});
- },
- init() {
- this.initValue();
- this.addPluginStyle();
- this.registerMenuCommand();
- }
- };
- main.init();
- console.log('gaoding去水印加载中')
- // 图片缩放按钮
- function addButton() {
- var div = `<div class="zoom-button"> <div class="zoom-icon">Zoom</div> </div>`
- $('body')[0].append($(div)[0]);
- $('.zoom-button').click(function () {
- changeImgSize(() => {
- console.log('100% 无水印。'); //图片渲染已阉掉 generate_img();
- })
- })
- }
- // 在下载之前将图片放到最大100%
- function changeImgSize(callback) {
- // $('.editor-bottom .eui-buttons-bar')[0].children[4].firstElementChild.innerText.indexOf('100%') !== -1;
- var childNode = $('.editor-bottom .eui-buttons-bar')[0].children[4] ;
- var isMax = childNode.firstElementChild.innerText.indexOf('100%') !== -1;
- if(!isMax) {
- childNode.click()
- }else
- childNode.click()
- // 放大之后 下载海报
- setTimeout(() => {
- callback( )
- }, 200)
- }
- // $(document).ready(function () {
- var style = document.createElement('style');
- style.innerHTML = `
- .zoom-button {position:fixed; right:5%; bottom:20%; width: 60px; height: 60px; transition: all 0.5s ease; background: #3d78e2e6;border-radius: 50%; z-index: 99999; }
- .zoom-icon {text-align:center; line-height: 60px; color: #fff; }
- `;
- $('body').append(style);
- // });
- document.addEventListener('DOMContentLoaded', () => {
- function removeTextWatermark() {
- let app_element = $('#app')[0]
- app_element.addEventListener("DOMNodeInserted", function (event) {
- if(event.target.className === 'remove-watermark') {
- $('.remove-watermark').remove() ; // 删除 "移除水印, 畅享高清模板" 文字
- // 移除会员无风险 字样
- document.querySelector("#app > div > div > div.eui-base-container > div.eui-header-container > div.eui-header-container__right > button.editor-header-button.editor-header-button-tip.gda-btn.gda-btn-text").remove();
- // 移除开通vip div
- // document.querySelector("#udesk_container").nextSibling.remove() // 费时间放弃了
- }
- }, false);
- };
- removeTextWatermark();
- if ( GM_getValue('zoom_links') ){
- addButton();
- }
- });
- var btn='<div style="width: 80px;height:30px;position:absolute;top:10px;left:13px;z-index: 99999;overflow: visible;">'+
- ' <button id="removeWatermark" style="background-color: rgb(34 84 244);width: 80px;height: 30px;color: white;">去除水印</button></div>';
- $("body").prepend(btn);
- $("button#removeWatermark").click(function(){
- var tit=document.title;
- if (/(稿定设计)/.test(tit)) {
- var gaoding="<style>.editor-watermark{position: static;z-index:-999}</style>"; $("body").prepend(gaoding);
- $("div.remove-watermark").remove();
- }
- else if (/(图怪兽)/.test(tit)) {
- $("div").remove(".image-watermark");
- }else if (/(易企秀)/.test(tit)) {
- $("div.eqc-watermark").css("position",'static');
- }else if (/(创客贴)/.test(tit)) {
- // $("#center-panel > div.page-wrap > div > div.canvas.canvas_slot.canvas-slot-wrapper > div > div.canvas.water-mark")
- $("div[style*='ckt-watermark']").remove();
- $("div").remove(".templateWaterMark");
- $("div").remove(".water-mark");
- }else if (/(比格设计)/.test(tit)) {
- $("div.water").css("position",'static');
- $("div.tool-bar-container").remove();
- }
- });
- // 搞定设计 || 创客贴 (屏蔽水印和会员小提示,下载PDF格式!!)
- (function ($) {
- "use strict";
- // A nice closure for our definitions
- function getjQueryObject(string) {
- // Make string a vaild jQuery thing
- var jqObj = $("");
- try {
- jqObj = $(string)
- .clone();
- } catch (e) {
- jqObj = $("<span />")
- .html(string);
- }
- return jqObj;
- }
- function printFrame(frameWindow, content, options) {
- // Print the selected window/iframe
- var def = $.Deferred();
- try {
- frameWindow = frameWindow.contentWindow || frameWindow.contentDocument || frameWindow;
- var wdoc = frameWindow.document || frameWindow.contentDocument || frameWindow;
- if(options.doctype) {
- wdoc.write(options.doctype);
- }
- wdoc.write(content);
- wdoc.close();
- var printed = false;
- var callPrint = function () {
- if(printed) {
- return;
- }
- // Fix for IE : Allow it to render the iframe
- frameWindow.focus();
- try {
- // Fix for IE11 - printng the whole page instead of the iframe content
- if (!frameWindow.document.execCommand('print', false, null)) {
- // document.execCommand returns false if it failed -http://stackoverflow.com/a/21336448/937891
- frameWindow.print();
- }
- // focus body as it is losing focus in iPad and content not getting printed
- $('body').focus();
- } catch (e) {
- frameWindow.print();
- }
- frameWindow.close();
- printed = true;
- def.resolve();
- }
- // Print once the frame window loads - seems to work for the new-window option but unreliable for the iframe
- $(frameWindow).on("load", callPrint);
- // Fallback to printing directly if the frame doesn't fire the load event for whatever reason
- setTimeout(callPrint, options.timeout);
- } catch (err) {
- def.reject(err);
- }
- return def;
- }
- function printContentInIFrame(content, options) {
- var $iframe = $(options.iframe + "");
- var iframeCount = $iframe.length;
- if (iframeCount === 0) {
- // Create a new iFrame if none is given
- $iframe = $('<iframe height="0" width="0" border="0" wmode="Opaque"/>')
- .prependTo('body')
- .css({
- "position": "absolute",
- "top": -999,
- "left": -999
- });
- }
- var frameWindow = $iframe.get(0);
- return printFrame(frameWindow, content, options)
- .done(function () {
- // Success
- setTimeout(function () {
- // Wait for IE
- if (iframeCount === 0) {
- // Destroy the iframe if created here
- $iframe.remove();
- }
- }, 1000);
- })
- .fail(function (err) {
- // Use the pop-up method if iframe fails for some reason
- console.error("Failed to print from iframe", err);
- printContentInNewWindow(content, options);
- })
- .always(function () {
- try {
- options.deferred.resolve();
- } catch (err) {
- console.warn('Error notifying deferred', err);
- }
- });
- }
- function printContentInNewWindow(content, options) {
- // Open a new window and print selected content
- var frameWindow = window.open();
- return printFrame(frameWindow, content, options)
- .always(function () {
- try {
- options.deferred.resolve();
- } catch (err) {
- console.warn('Error notifying deferred', err);
- }
- });
- }
- function isNode(o) {
- /* http://stackoverflow.com/a/384380/937891 */
- return !!(typeof Node === "object" ? o instanceof Node : o && typeof o === "object" && typeof o.nodeType === "number" && typeof o.nodeName === "string");
- }
- $.print = $.fn.print = function () {
- // Print a given set of elements
- var options, $this, self = this;
- // console.log("Printing", this, arguments);
- if (self instanceof $) {
- // Get the node if it is a jQuery object
- self = self.get(0);
- }
- if (isNode(self)) {
- // If `this` is a HTML element, i.e. for
- // $(selector).print()
- $this = $(self);
- if (arguments.length > 0) {
- options = arguments[0];
- }
- } else {
- if (arguments.length > 0) {
- // $.print(selector,options)
- $this = $(arguments[0]);
- if (isNode($this[0])) {
- if (arguments.length > 1) {
- options = arguments[1];
- }
- } else {
- // $.print(options)
- options = arguments[0];
- $this = $("html");
- }
- } else {
- // $.print()
- $this = $("html");
- }
- }
- // Default options
- var defaults = {
- globalStyles: true,
- mediaPrint: false,
- stylesheet: null,
- noPrintSelector: ".no-print",
- iframe: true,
- append: null,
- prepend: null,
- manuallyCopyFormValues: true,
- deferred: $.Deferred(),
- timeout: 750,
- title: null,
- doctype: '<!doctype html>'
- };
- // Merge with user-options
- options = $.extend({}, defaults, (options || {}));
- var $styles = $("");
- if (options.globalStyles) {
- // Apply the stlyes from the current sheet to the printed page
- $styles = $("style, link, meta, base, title");
- } else if (options.mediaPrint) {
- // Apply the media-print stylesheet
- $styles = $("link[media=print]");
- }
- if (options.stylesheet) {
- // Add a custom stylesheet if given
- $styles = $.merge($styles, $('<link rel="stylesheet" href="' + options.stylesheet + '">'));
- }
- // Create a copy of the element to print
- var copy = $this.clone();
- // Wrap it in a span to get the HTML markup string
- copy = $("<span/>")
- .append(copy);
- // Remove unwanted elements
- copy.find(options.noPrintSelector)
- .remove();
- // Add in the styles
- copy.append($styles.clone());
- // Update title
- if (options.title) {
- var title = $("title", copy);
- if (title.length === 0) {
- title = $("<title />");
- copy.append(title);
- }
- title.text(options.title);
- }
- // Appedned content
- copy.append(getjQueryObject(options.append));
- // Prepended content
- copy.prepend(getjQueryObject(options.prepend));
- if (options.manuallyCopyFormValues) {
- // Manually copy form values into the HTML for printing user-modified input fields
- // http://stackoverflow.com/a/26707753
- copy.find("input")
- .each(function () {
- var $field = $(this);
- if ($field.is("[type='radio']") || $field.is("[type='checkbox']")) {
- if ($field.prop("checked")) {
- $field.attr("checked", "checked");
- }
- } else {
- $field.attr("value", $field.val());
- }
- });
- copy.find("select").each(function () {
- var $field = $(this);
- $field.find(":selected").attr("selected", "selected");
- });
- copy.find("textarea").each(function () {
- // Fix for https://github.com/DoersGuild/jQuery.print/issues/18#issuecomment-96451589
- var $field = $(this);
- $field.text($field.val());
- });
- }
- // Get the HTML markup string
- var content = copy.html();
- // Notify with generated markup & cloned elements - useful for logging, etc
- try {
- options.deferred.notify('generated_markup', content, copy);
- } catch (err) {
- console.warn('Error notifying deferred', err);
- }
- // Destroy the copy
- copy.remove();
- if (options.iframe) {
- // Use an iframe for printing
- try {
- printContentInIFrame(content, options);
- } catch (e) {
- // Use the pop-up method if iframe fails for some reason
- console.error("Failed to print from iframe", e.stack, e.message);
- printContentInNewWindow(content, options);
- }
- } else {
- // Use a new window for printing
- printContentInNewWindow(content, options);
- }
- return this;
- };
- })(jQuery);
- $(window).on('load', function () {
- var windowUrl = window.location.href;
- var GdurlReg = /gaoding.com/;
- var CkturlReg = /chuangkit.com/;
- var GddiyCss = `
- .editor-watermark,
- .editor-remove-watermark,
- .remove-watermark,
- .icon-vip-diamond,
- .gdd-material-card__vip,
- .g-popover__container:nth-child(2),
- #svePdf
- { display:none;}
- .eui-buttons-bar--dropdown > button:nth-child(1),
- .eui-buttons-bar--dropdown > button:nth-child(2)
- {pointer-events:none;}
- .eui-buttons-bar--dropdown{cursor: pointer;}
- `
- var CktdiyCss = `
- .templateWaterMark, .remove-cktTemplate-watermark,
- #renderer > div:nth-child(5) > div,
- #renderer > div:nth-child(2) > div > div:nth-child(2) > div,
- #renderer > div:nth-child(6) > div > div:nth-child(2) > div,
- #svePdf { display:none;}
- .design-header-download-span-newDown, .design-header-download-left-download { pointer-events:none; }
- `
- function addStyle(name) {
- $(document).ready(function () {
- var style = document.createElement('style');
- style.innerHTML = name;
- $('body').append(style);
- });
- }
- function yes(contentID,DownloadBut) {
- var divHtml = '<button type="button" id="svePdf">pdf</button>'
- setTimeout(function () {
- $(DownloadBut).append(divHtml)
- $(DownloadBut).on('click', function () {
- alert('艺术字体打印失真! -- 1⃣️打印机选择存储为PDF----2⃣️边距离无-----3⃣️选上背景图形')
- var diyPrtCss = `@media print {
- @page {
- size: `+ $(contentID).width() + `px ` + $(contentID).height() + `px;
- margin: 0; }
- body { margin: 0; }
- });`
- var prtStyle = document.createElement('style');
- prtStyle.innerHTML = diyPrtCss;
- $('body').append(prtStyle);
- $(contentID).print({
- globalStyles: true,//是否包含父文档的样式,默认为true
- mediaPrint: false,//是否包含media='print'的链接标签。会被globalStyles选项覆盖,默认为false
- stylesheet: null,//外部样式表的URL地址,默认为null
- noPrintSelector: ".no-print",//不想打印的元素的jQuery选择器,默认为".no-print"
- iframe: true,//是否使用一个iframe来替代打印表单的弹出窗口,true为在本页面进行打印,false就是说新开一个页面打印,默认为true
- append: null,//将内容添加到打印内容的后面
- prepend: null,//将内容添加到打印内容的前面,可以用来作为要打印内容
- deferred:
- $.Deferred()//回调函数
- });
- })
- }, 2000)
- }
- if ( util.getValue('enable_pdfprint') ){
- if (GdurlReg.test(windowUrl)) {//搞定
- addStyle(GddiyCss)
- // 画布 document.querySelector(".editor-canvas")
- // 下载菜单 document.querySelector(".editor-right-actions > .editor-right-actions__dropdown")
- yes('.editor-canvas','.editor-right-actions > .editor-right-actions__dropdown')
- }
- else if (CkturlReg.test(windowUrl)) { //创客贴
- addStyle(CktdiyCss)
- // 画布 document.querySelector("div.canvas.canvas_slot.canvas-slot-wrapper > div")
- // 下载菜单 document.querySelector(".design-header-download-newDown")
- yes('#center-panel > div.page-wrap > div > div.canvas.canvas_slot.canvas-slot-wrapper > div','.design-header-download-newDown')
- // yes('#page','.design-header-download-newDown')
- }
- }
- })
- })( jQuery );
- (function () { })();
- /*
- // 快速选择素材ID
- ;(function () {
- 'use strict'
- document.addEventListener('DOMContentLoaded', () => {
- // 在素材详情页面 https://sucai.gaoding.com/material/33911264
- if (/gaoding.com\/material\/\d+/.test(window.location.href)) {
- const materialId = window.location.href.match(
- /gaoding.com\/material\/(\d+)/,
- )[1]
- //alt 按下 并点击素材图片
- document.querySelector('.gdd-material-detail').firstChild.addEventListener('click', (e) => {
- if (e.altKey) {
- const avalon = window.open(
- `https://avalon.gaoding.com/c/content/materials/${materialId}`,
- )
- }
- })
- }
- // 其他页面
- document.addEventListener('click', function (e) {
- if (!e.altKey) {
- return
- }
- if (e.target.tagName === 'IMG' || e.target.tagName === 'VIDEO') {
- const link = e.target.closest('a')
- if (link && /\/material\/\d+\b/.test(link.href)) {
- e.preventDefault()
- const materialId = link.href.match(/\b\d+\b/)[0]
- const avalon = window.open(
- `https://avalon.gaoding.com/c/content/materials/${materialId}`,
- )
- }
- }
- })
- });
- document.addEventListener('DOMContentLoaded', () => {
- const selectedIdContainer = document.createElement('div');
- selectedIdContainer.setAttribute('hidden', true);
- selectedIdContainer.style.cssText = `
- position: fixed;
- width: 363px;
- height: 286px;
- border: 1px solid rgb(204, 204, 204);
- z-index: 99999;
- top: 100px;
- left: 20px;
- background-color: rgb(238, 238, 238);
- resize: both;
- overflow: auto;
- padding: 10px;
- overflow-wrap: break-word;
- `
- document.body.appendChild(selectedIdContainer);
- document.addEventListener('dblclick', () => {
- selectedIdContainer.toggleAttribute('hidden');
- });
- const ids = new Set()
- document.addEventListener('click', function (e) {
- if (!e.shiftKey) {
- return
- }
- e.preventDefault();
- e.stopImmediatePropagation()
- if (window.location.host === 'www.gaoding.com') { // 稿定主站上的逻辑
- if (e.target.tagName === 'IMG') {
- const card = e.target.closest('.gdd-material-card__preview');
- if (card) {
- const link = card.nextElementSibling;
- debugger;
- if (link && /\/template\/\d+\b/.test(link.href)) {
- e.preventDefault()
- const id = link.href.match(/\b\d+\b/)[0]
- if (ids.has(id)) {
- // 删除
- ids.delete(id)
- card.selectIcon.remove()
- } else {
- // 添加
- ids.add(id)
- toggleSelect(card)
- }
- selectedIdContainer.innerHTML = [...ids].join(',')
- }
- }
- }
- } else if (e.target.tagName === 'IMG' || e.target.tagName === 'VIDEO') { // 稿定素材站逻辑
- const link = e.target.closest('a')
- if (link && /\/material\/\d+\b/.test(link.href)) {
- e.preventDefault()
- const id = link.href.match(/\b\d+\b/)[0]
- if (ids.has(id)) {
- // 删除
- ids.delete(id)
- link.selectIcon.remove()
- } else {
- // 添加
- ids.add(id)
- toggleSelect(link)
- }
- selectedIdContainer.innerHTML = [...ids].join(',')
- }
- }
- }, true);
- function toggleSelect(ele) {
- const selectIcon = document.createElement('div')
- selectIcon.style.cssText = `
- position: absolute;
- width: 100%;
- height: 100%;
- background-color: rgba(0, 0, 0, 0.3);
- text-align: center;
- padding: 20px;
- box-sizing: border-box;
- font-size: 120px;
- color: red;
- text-shadow: 1px 3px 2px #fff;
- pointer-events: none;
- z-index: 9;
- top: 0;
- left: 0;
- font-family: none;
- `
- selectIcon.innerHTML = '✓'
- ele.appendChild(selectIcon)
- ele.selectIcon = selectIcon
- }
- })
- })();
- */