This is an archive of past discussions on Wikipedia:User scripts. Do not edit the contents of this page. If you wish to start a new discussion or revive an old one, please do so on the current talk page.
It is my understanding that the Wikimedia Foundation's official stance is it will not run any ads. There have been some serious proposals for an opt-in ad system, but nothing has come out of it.
On the other hand, opt-in ads are something that can be easily implemented in a user script. For example, I could sign up for an ad exchange service (such as Infolinks) and put the ad-generating code in a script here. Any money that is gained can then be donated to Wikipedia.
However, there are a few potential problems with this approach. Because the Wikimedia Foundation does not officially run ads, there would be no oversight: a less-than-honest person could keep some of the funds for himself. Also, if a user does something that violates the ad exchange's terms of service, it could sever ties between the service and Wikipedia. This could become problematic should Wikipedia ever "needs" ads.
I recently got a new laptop, and I don't get my javascript any more on no:Wikisource. (I neither get my additional edit buttons, nor the [common] box of edit tools under the edit window. Is there something wrong with my javascript or some plug-in/add-on that I don't have? V85 (talk) 04:21, 6 May 2013 (UTC)
Have there been any significant efforts/discussions about adapting BeeLine Reader as a user script?
The issues with the existing implementation are as follows:
A quick look at the bookmarklet shows that it loads some scripts/stylesheets from www.beelinereader.com without https. The Firefox extension seems to have that problem too.
HTTPS support?
www.beelinereader.comappears to be hosted on Heroku at beelinereader.herokuapp.com, so an HTTPS Everywhere rule could conceivably be written. However, that would leave functionality broken due to compatibility issues between mixed-content blocking and HTTPS Everywhere (Firefox, Chrome).
I could work around that by making on-wiki copies of the dependencies, except that I would like the script only to change text colors without doing any of the other reformatting it currently does. This is somewhat nontrivial for me to figure out, given the length of the script that does the actual work.
To clarify, it is possible that the "readability" script only does the aforementioned "reformatting," and the colors are handled elsewhere. --SoledadKabocha (talk) 03:16, 15 December 2013 (UTC)
Upon digging a bit further, it is indeed the case that the coloring is handled separately from readability.js; the files have different names depending on the color scheme chosen (see the radio buttons on the bookmarklet installation page, and look at the resulting code of the bookmarklet). For example: BlackNavyCrimson.js for the "Dark" color scheme. An obvious change that would need to be made (in addition to removing the Google Analytics stuff) is that the readInner element ID would need to be changed to bodyContent or content if the page isn't going to be preprocessed by Readability.
At this point I think I can handle this myself. I don't intend for this to be developed as a gadget or otherwise widely publicized; that could run into licensing issues anyway. --SoledadKabocha (talk) 03:36, 15 December 2013 (UTC)
I have gone looking for admins who would like to approve a proposal I made for a gadget that disables search suggestions. Recently, one of them referred me to this project.
The project page says that the "most popular" scripts become gadgets. What usage is this approximately? The core preference to disable suggestions was used by 112 editors and some others couldn't find it. At least 7 of them have voiced their desire to get this option back in a discussion and a developer has encouraged me to write a similar gadget. The sheer number of search suggest bugs both technical and philosophical makes me surprised that the option would ever be taken out of core.
Are these reasons enough to have my script added as a gadget? If not, I am happy to list it on the project page so we can first make sure that it gets enough usage. I just hope this gets the attention of someone who can make the decision. Connor Behan (talk) 05:59, 6 February 2014 (UTC)
Need script to filter navboxes in "What links here"
When using the tool "What links here" for geographical entries (such as Wichita Falls, Texas), all links in navboxes are listed as well as the usual article links. For someplace like Texas, this makes hundreds and hundreds of links to wade through. Would it be possible to make a user script that would filter out everything in navboxes? Or is there one already I haven't found? Many thanks. - Gorthian (talk) 19:39, 19 April 2014 (UTC)
I think that would require the script to request and download all these hundreds of articles in order to check whether the link is in a template or not, not really a good idea. --V111P (talk) 08:48, 20 April 2014 (UTC)
That wouldn't quite work, as many small cities in Texas have the template without being in the template (e.g. Hutchins, Texas). --V111P (talk) 13:43, 21 April 2014 (UTC)
I was thinking something along the lines of an invisible something in the navbox template that would tell the script "here are the links contained within," and then the script could note those and ignore them. Obviously, I'm no programmer; I don't know how any of this works. - Gorthian (talk) 19:25, 21 April 2014 (UTC)
No, I just used the template's "What links here" backlinks instead of the links in the template and it works! The former include all the pages that transclude the template. Thanks for the idea, Gorthian! I'll post the script a little later. --V111P (talk) 19:42, 21 April 2014 (UTC)
Here is the documentation for the script: User:V111P/js/What Links Here link filter. Tell me if you have any problems because I haven't done much testing. I tested it on Whichita Falls, Texas with Namespace set to (Article) and templates:
County, Texas|Template:Texas|Template:Texas county seats|Template:Texas cities and mayors of 100,000 population|Template:Texas counties
It reduces the pages from 1841 to 755. Well, that's still a lot of pages... but I hope it's helpful anyway.
If you want, Gorthian, you can try some of my other scripts too and tell me if you like/don't like them. Thanks. --V111P (talk) 06:52, 22 April 2014 (UTC)
Asynchronous ends too late
Hello. Here is a basic script that queries the API as explained in the documentation. But the result arrives too late, because the JS continues without waiting the api.get() finish, and numberOfEditors is [0, 0]. How can I stop the run until api.get() is really ".done()" ? emijrp (talk) 18:14, 22 June 2014 (UTC)
You cannot use return in a callback; when done() is fired, there is nothing to return to, because the function already returned [0, 0]. You need to point the callback to a separate function. -- [[User:Edokter]] {{talk}}21:57, 22 June 2014 (UTC)
Using asynchronous I/O really requires a different way of looking at how a program operates. Assuming that you do not have significant additional processing to perform while the asynchronous operation is in process, you need to complete whatever operations you can/should do prior to getting the data from the asynchronous operation and then just return. You rely on getting a callback from the async op to start your processing back up again. You absolutely should not just sit and spin in a loop waiting for a flag to be set indicating completion. Doing so effectively changes the async op to synchronous which undermines the purpose of having asynchronous operations.
The typical method to accomplishing this is that you continue everything that should happen after the asynchronous action is complete from the callback function passed to the function which actually initiates the asynchronous action. Very specifically, there is a period of time during which your script is not actually running, except for the asynchronous action.
Conceptually, you really should not view it as something like a synchronous readFile(), but more of a requestURL(callWhenDataAvailable,callIfError). Your processing then stops, you return(), until you get a response. You should also set up a timeout so that you definitely get a callback to something that makes your script return to being processed. You should also initiate the async request as soon as you know that you are going to need it. Given that JS is, generally, single threaded, you don't have to worry about the issue of having the callback routing being called while you are still completing your initial processing.
I'm not sure I've done a decent job of explaining this, but how much of the surrounding concepts should be explained here is not clear. From your question, the fundamental thing that appears to be an issue is that you have not made the paradigm shift in your thinking from how to use synchronous I/O to how to use asynchronous I/O. One of the things that appears to help people conceptually is to use the difference in nomenclature I indicated above (i.e. don't use getURL(), but requestURL()). This helps keep in mind that you are actually making a request for the data rather than starting a blocking I/O operation. — Makyen (talk) 00:53, 23 June 2014 (UTC)
Why are there no easy links to preloads to install scripts more easily? For example this link : [1] will automatically fill in the contents of the Template:! on a new section of the sandbox. Similarly, code could be appended to the bottom of the user's script page via preloads. The preload could perhaps be stored on the User:Example/Script.js/preload page. That would mean installing the script is only 1 click to open the user's script page, and 1 click to submit - instead of requiring the users to copy over the contents themselves.
From personal experience I say that in general it's best to do the work for users as much as possible, when it comes down to code. Of course this would not automatically insert the preload-link, but I think it would be good to add the option to add a preload link to the template. Any thoughts? Joeytje50 (talk) 21:28, 23 February 2014 (UTC)
Creating these extra preload pages and hiding from the user what is actually happening is not a good idea in my opinion. Plus we can't have new sections in the script files. But thanks for the suggestion. --V111P (talk) 08:58, 20 April 2014 (UTC)
A script could be made that adds a script to the user's javascript file. It would load the text of the file, append the new importScript() call, and edit the page with the new text. Then the user would only have to add a script once and then simply click a button to add new scripts. It could even be made to remove scripts if desired.--Dudemanfellabra (talk) 17:06, 20 April 2014 (UTC)
You can try Equazcion's ScriptInstaller. Having to install a script in order to install another script kind of defeats its purpose though. But if you want to try many different scripts it makes sence. --V111P (talk) 23:24, 20 April 2014 (UTC)
I think what you are asking for is detailed in the bug report I've tracked above and to the right. Maybe it will happen... I'm hoping. — {{U|Technical 13}} (e • t • c)01:29, 23 June 2014 (UTC)
Add only local scripts?
Means this page that only local "English WP" scripts are allowed? Script functions are mostly language independent (or can be made multilingual extended), is it not useful to add some more existing Wiki scripts? Concretely I would suggest an auto. signing script and an auto. section link corrector for the edit summary. This could also be useful as moduls for other scripts!? → User: Perhelion22:39, 22 June 2014 (UTC)
No, the scripts should work on this Wikipedia and they should be documented in English, but their source code doesn't have to be on the English Wikipedia. --V111P (talk) 19:03, 23 June 2014 (UTC)
Automatic totals for a table?
Following a discussion at WT:FOOTY#Career totals template, we were wondering if anyone here would be able to create a script to automatically total up the numbers from the rows above. For example, this could be used for medal tables, where the bottom row is a sum of all medals won, or for career statistics, such as at Scott Loach#Career statistics. - 97rob (talk) 15:30, 6 June 2014 (UTC)
Go to your common.js page and remove the line that imports any scripts you no longer want to affect your skin. You may have also added some custom CSS to your common.css page which you may want to remove.
Gadgets are another possible way your skin may have been changed.
For a completely default (vanilla) experience, reset all your gadgets to the default, and remove all the text from both your common.js and common.css pages. That should do it. fredgandt01:40, 8 August 2014 (UTC)
Hello. I'm starting to do user scripts, previously I did mostly Python bots. I'm thinking about a user script that shows charts/graphs using Flotr library or similar. Is it possible to use these libraries in a user script? How? Thanks. emijrp (talk) 18:00, 22 June 2014 (UTC)
You can copy the contents of excanvas.min.js to a sub page of your user page and then load it from the main file of your user script, for example with mw.loader.load('//en.wikipedia.org/w/index.php?title=User:Emijrp/excanvas.min.js&action=raw&ctype=text/javascript'). You should also include the license [2] somewhere (the original Github page may disappears one day so just adding a link to it may not be enough). Another option is to try to load excanvas.min.js directly from Github, but I'm not sure if that's a good idea. --V111P (talk) 19:38, 23 June 2014 (UTC)
The simplest thing to do would be to copy the whole script directly into your user script. But what I like to do is to have a small main script file which loads the larger script when the user requests to use the tool. --V111P (talk) 23:45, 23 June 2014 (UTC)
@Helder.wiki: Good question. I believe it is one-way compatible provided you keep the copyright notice, which is also required by CC-BY-SA. But of course, I'm not a lawyer, so I can't say for sure. To clarify, the question is whether you can copy the script to Wikipedia, I see no possible problem with importing the script from somewhere else with mw.loader.load(). --V111P (talk) 17:16, 9 August 2014 (UTC)
@Helder.wiki: Now I realize that technically we should probably license our user scripts with GPL v. 2 or later at least in addition to the default CC-BY-SA, otherwise we may be in violation of the license of the MediaWiki JavaScript modules we are using, including mw.loader. --V111P (talk) 22:22, 9 August 2014 (UTC)
Copying from logs of IRC channel #wikimedia-devconnect:
<helderwiki> Since mw code is under GPL, does that mean any user script using mw.loader must also be licensed as GPL? <helderwiki> (context: https://en.wikipedia.org/w/index.php?diff=620559132 ) <MatmaRex> whaaa? no <MatmaRex> disclaimer: i am not a lawyer
* helderwiki neither <MatmaRex> but i don't see how MW being licensed under GPL would force the on-wiki scripts to also be <MatmaRex> it's not distributed together with them or anything <helderwiki> Doesn't using these libraries makes the code "linked" to MW somehow? <p858snake|l> iirc this has been discussed hundreds of time on the ML <p858snake|l> and the answer is no
I'm also not a lawyer, but the way I'd look at it is from an almost purely technical perspective.
A library imported by and for a user script is imported by the user, not by Wikipedia (JS being client side and all), so if the library is free to use in/on projects by whomever (unless you can somehow control who uses the script), load away!
Consider if you will that use of Google's Maps in web pages must (Google says so, and that's the webmaster's agreement with Google) be accompanied by a clear privacy statement pointing out to the user of that web site, that by continued use, thay are agreeing to Google's use and privacy policies. It's not the webmaster that uses the Maps, it's the end user, so they're the ones who have to agree and be bound by Google's licencing and policies.
The webmaster may have other policies and agreements with Google regarding the use of those imported resources, but they're strictly between the webmaster and Google, and have no practical bearing on the agreements between the end user and Google.
However, the actual text added to any Wikipedia page could be contentious. i.e The call to load the library may need attribution(?) and certainly a full copy of a library might (depending on it's usage licencing thing).
Hello there! As you may already know, most WikiProjects here on Wikipedia struggle to stay active after they've been founded. I believe there is a lot of potential for WikiProjects to facilitate collaboration across subject areas, so I have submitted a grant proposal with the Wikimedia Foundation for the "WikiProject X" project. WikiProject X will study what makes WikiProjects succeed in retaining editors and then design a prototype WikiProject system that will recruit contributors to WikiProjects and help them run effectively. Please review the proposal here and leave feedback. If you have any questions, you can ask on the proposal page or leave a message on my talk page. Thank you for your time! (Also, sorry about the posting mistake earlier. If someone already moved my message to the talk page, feel free to remove this posting.) Harej (talk) 22:48, 1 October 2014 (UTC)
User script suddenly not working any more
I use User:קיפודנחש/watchlistScout.js to alert me when something on my watchlist changes. It is supposed to run on page load and refresh every 60 seconds afterwards. For the past day or so, though, I have been getting nothing from the script. All of my other scripts are working, I'm getting no errors on the javascript console, and it doesn't look like anything has changed in the code of the script recently (latest change was in 2012). Is there something else that may have changed site-wide that broke the script? Possibly an update to the API or something?--Dudemanfellabra (talk) 05:58, 11 October 2014 (UTC)
I recently updated my own watchlist-related scripts to fix bugs which had caused them to be broken for over a year. I was wondering if that was causing your problem, but you apparently don't have them installed, so that probably isn't the cause. This doesn't fix your problem, but I thought I'd mention it in order to prevent other people searching blind alleys. --ais523 07:09, 11 October 2014 (UTC)
Hmm I suppose I should have done that--or at least pinged him/her--but since nothing had changed with the JS file itself and User:קיפודנחש's contributions don't show any recent edits that would have affected the script, I figured it wasn't his/her fault but some other error like a site-wide change that may have affected more than just this script. Seeing as how the people that watch this talk page are well versed in user scripts, I figured here would be a good place to ask. I also asked at the help desk, and they directed me to VPT, where I'm about to post as well.--Dudemanfellabra (talk) 02:32, 14 October 2014 (UTC)
Anyone know which gadget / tool / script / bot -- it is that re-orders cites for articles in the right order?
What's the tool / gadget / script / bot -- that automatically or semi-automatically checks for archived versions of URLs and adds them into the citations with archiveurl parameter?
GB I think for #2 he means searching webcite for archived versions of pages that now return 404 errors. If the citation was already there, it wouldn't be unreasonable to have a bot find a webcite version for it if it became a deadlink. That said, I have no idea what bot would do that. — {{U|Technical 13}} (e • t • c)03:59, 7 November 2014 (UTC)
WikiProject X is live!
Hello everyone!
You may have received a message from me earlier asking you to comment on my WikiProject X proposal. The good news is that WikiProject X is now live! In our first phase, we are focusing on research. At this time, we are looking for people to share their experiences with WikiProjects: good, bad, or neutral. We are also looking for WikiProjects that may be interested in trying out new tools and layouts that will make participating easier and projects easier to maintain. If you or your WikiProject are interested, check us out! Note that this is an opt-in program; no WikiProject will be required to change anything against its wishes. Please let me know if you have any questions. Thank you!
Note: To receive additional notifications about WikiProject X on this talk page, please add this page to Wikipedia:WikiProject X/Newsletter. Otherwise, this will be the last notification sent about WikiProject X.
To delete the userpage, block the account, and post at the user's talk.
This is something I do hundreds of times exactly the same way. A script would make things so fast. I do this when I am at the userpage. It is an advert that says something like "Our mission is to provide great cosmetics. Try us!" and the username is something like "Maryspam Idiotic Cosmetics Co. Ltd." The steps goes like this:
Steps
1. Select the "delete" tab. Delete the page with the reason "G11: Unambiguous advertising or promotion."
2. Select "block user".
3. From the "Expiry:" dropdown menu, select "indefinite".
4. From the "Reason:" dropdown menu, select {{spamusernameblock}}
5. Leave the tickboxes as default.
6. Click block to block.
7. Go to the user talk page and click new section.
8. Paste {{subst:User:Anna Frodesiak/Cuw-soa-block}} ~~~~ and save.
I apologize Anna, I totally forgot about your request for this, and it has been a long time you have been waiting. It most certainly can be done, and it's actually easier than what you have listed here. I'll have to dig up my research I did on this project, and I'll post whatever help I can here. If no-one else wants to pick up where I left off and work on this, I'll see if I can't put something together in a few days. — {{U|Technical 13}} (e • t • c)14:04, 24 November 2014 (UTC)
Not at all. I just figured you were busy. Anyway, I would just love to have this script. It would save me oceans of time which I could apply to the mainspace instead to help make Wikipedia better. :) Anna Frodesiak (talk) 15:51, 24 November 2014 (UTC)
And also, I would advertise this script in the admin IRC channel and lots of other admins would use it. It is a common action we all do manually. Anna Frodesiak (talk) 15:52, 24 November 2014 (UTC)
Been thinking about this, Anna, and have started putting together User:Technical_13/SandBox/SpamUNblocker.js. Currently, it does all of what you want at a most basic level as in it opens three new tabs (one to delete, one to block, and one to notify) with all of the settings that you want. The reason I've done it like this for now in this alpha stage is to give you a chance to review the action you are about to take instead of just having it done for you with no review. Once I make sure that everything is working exactly as intended, then I'll start making parts of it automated so eventually one click will carry out all three steps automatically. I'll note that with my current setup, you'd have to change your template slightly for the talk page block notice to mirror testwiki:User:Anna Frodesiak/Cuw-soa-block to have your signature in there automatically (otherwise you can simply add it manually on the end). — {{U|Technical 13}} (e • t • c)21:36, 25 November 2014 (UTC)
Hi, I would also benefit hugely from a script like this. However I'd want it to post the {{spamusernameblock}} on the user talk page. Perhaps make it configurable? For more generalized use I would say have {{spamusernameblock}} be the default but make it so that it can be overridden but putting var spamublockTemplate="User:Whomever/customTemplate" at the top of your common.js (or wherever you import your scripts). In other words, the script would see if spamublockTempalte is set and if it is use that, otherwise just use {{spamusernameblock}}. How does that sound? Thanks! — MusikAnimaltalk23:40, 25 November 2014 (UTC)
I can easily do that, but you'll have to manually add your signature. The alternative would require me to be in the template editor or administrator user groups to edit protected pages, and I'm not really interested in being in either group at this time. Fair enough? — {{U|Technical 13}} (e • t • c)23:55, 25 November 2014 (UTC)
Actually, on further thought, I may be able to change the way I'm doing a few other things to accommodate this request without additional effort by the end user (you). Let me play with some ideas to accomplish this tomorrow or after the Thanksgiving holiday. — {{U|Technical 13}} (e • t • c)03:12, 26 November 2014 (UTC)
@Technical 13: Well, for the record, I'm happy to assist you in any way :) I'm a bit of a coder myself. This all sounds like a fun project. Do you know if it is possible to perform the actual block with JavaScript? I'm not aware of any scripts that do this, but I know Twinkle can do some admin bits like page protection. Also, is there a good go-to resource for all the available MediaWiki JavaScript functions? I've just been learning as I go along from existing scripts. Thanks! — MusikAnimaltalk03:30, 26 November 2014 (UTC)
MA, the three parts of this script could be accomplished through the API automatically using mw:Manual:Ajax with mw:API:Block to block the editor, mw:API:Edit to post the notice on the talk page, and mw:API:Delete to delete the violation. While I've taken some advanced Javascript classes in school, there are a lot of the ever evolving mw:JavaScript libraries that I'm not completely familiar with and exceed my current comfort level (whether or not I can actually implement it). — {{U|Technical 13}} (e • t • c)03:50, 26 November 2014 (UTC)
Is the current method of opening three new tabs and allowing review before pulling the trigger on each phase a preferred way to do it, or should I pursue modifying the script to take the requested actions on your behalf without the "confirmation step"? I have no idea what might be most efficient and preferred. If there is a variety of opinions on this, I may see if I can make it a toggled preference. Thanks. — {{U|Technical 13}} (e • t • c)03:12, 26 November 2014 (UTC)
Three tabs? I open the userpage and if I discover a blatant ad, and the username is a company, and I see the edit count as "1", then it is almost certain that I will want to run this script. It would be nice to end it on the talk page in case there's a message about deleted article. I would sometimes also check the deleted contribs after that. But, this script is for accounts that registered only a few minutes earlier, so the chances are very high that the only thing that the user did was paste an advert and that's it. When you say "3" tabs, if you mean the block page being one, then I would never want to open it if I can use this script. The script would do it for me. I would start on the userpage, make a decision to run the script, and then would be taken to the usertalk page so I could see that the block notice has been placed, the user has been blocked, and the userpage tab is now redlinked. Anna Frodesiak (talk) 05:41, 1 December 2014 (UTC)
Anna, what I mean is that when you run the current script, it opens up three new tabs for you. It opens up a tab (new window?) for deleting the user page (tab 1), then it opens a tab (new window?) to leave your custom message on the user's talk page (tab 2), finally, it opens a tab (new window?) to block the user (tab 3). The third tab has focus (since it was opened last) so you can quickly block to prevent them from doing any more damage. I figured the next most important thing was to notify them, so this was tab 2 so when you complete the blocking process and close that tab, you are defaulted here. I figured cleaning up and deleting the user page was of the least importance, so it opens that one first so it is the last one you get to be default. You can easily do things in any order on a case-by-case basis by clicking the tab you want to process next. So, to be clear, three tabs == {block, talk, delete}. Yes, you run it from the userpage, and it opens three pages. I don't currently have it set up to close the tab that you launch it from, but I suppose that would be easy enough if it would help. :) Also, to try and be clear, it is currently not set up to do all the work for you automatically through the api, it is set up to simplify the process by opening pages you want (block, talk, delete) with all of the settings preset for you. What I'm wondering is if this is a better idea so you can either click "Block" or "Delete" or "Save page" or on a case-by-case basis maybe change a setting here or there (like maybe you want to block talk page or email access for a particular one) before preforming the action. Q: Have you tried the script yet (here or on testwiki) to see how it works? If you need testwiki admin bit to test it, I'd be happy to give it to you and to set you up for this. — {{U|Technical 13}} (e • t • c)06:47, 1 December 2014 (UTC)
I'm so sorry. I'm going to drive you bonkers. :) For me, I need no options and no pages left open everywhere. I would ideally like to be looking at a userpage with no tabs open. Click a button, no options, no case-by-case. Then, as if by magic (which is pretty much what scripts are to me), the userpage gets deleted, the user spamblocked, and a standard template glued to the bottom of his usertalk. I am then brought to the usertalk with nothing else open anywhere. That's it. Can that be done?
You mention "prevent them from doing any more damage". The scenario for which I want to use the script is always the same. It is a new user who drops and advert with a single edit and then you never see him edit again. There are tons of those.
Try it, you ask? I'd love to. But how? I do not even know how to install the thing. It is one of those bits of code I stick in the ...js something-or-other? Anna Frodesiak (talk) 06:59, 1 December 2014 (UTC)
Ah, okay I found it. It was in a dropdown menu at the top. I clicked it. It brought up a the delete page page prompting me to choose advert reason. I clicked it. that was all it did. Anna Frodesiak (talk) 07:19, 1 December 2014 (UTC)
Anna, I'm back on this task. Due to your popup blocker issue, I've basically scrapped the entire script that I had. This new version will have an interface and do everything for you (without opening pages for you to do it yourself). Due to the great deal of added complexity of this new version, it may take me a little while to complete. I'll ping you again when I have a semi-working prototype. What would would really useful for me, is if you can create an account on testwiki (maybe AnnaTheSpammer or something silly like that) and make a few edits like what you normally see from these users so I can have a "test case" to work with. Thanks! — {{U|Technical 13}} (e • t • c)15:23, 4 January 2015 (UTC)
I'm sorry to give you all this work. Isn't it possible to just supress the popups and make the darn thing do all three steps all tied together and in the background? Anna Spamdesiak (talk) 15:31, 4 January 2015 (UTC) (Anna Frodesiak (talk) 15:33, 4 January 2015 (UTC))
Don't be sorry, from the discussion above, it seems like this will be useful to at least a few admins. As for your question, yes, but that is what is causing all the work. :p lol no worries, I'm enjoying doing it. — {{U|Technical 13}} (e • t • c)17:02, 4 January 2015 (UTC)
@Mr. Stradivarius: Nice work! I like that it can handle uw-softerblock as well. I've been using User:MusikAnimal/spamublock which is more of a quick and dirty solution to the {{uw-spamublock}}, using only default block options. It also works on mainspace articles, as you'll often see the spamublock scenario with the page creator there as well. I'm sure you could incorporate that easily! Adding something like this to the Twinkle block module is on the back-burner, just so ya know, and you are welcome to help out with that! :) Cheers — MusikAnimaltalk14:35, 18 June 2015 (UTC)
@Mr. Stradivarius: Very nice work indeed! Thank you very much. I must apologize for not adding a comment here that said MusikAnimal already made a type of this. I like your options and will use it too, as will others I am sure. Thank you again!!! :) Anna Frodesiak (talk) 22:30, 18 June 2015 (UTC)
Request for "reply to talk page comment" script
Heya,
Is it possible to make a script that'll let you reply with a ping with one click to signed comments on talk pages? Current steps to do this are:
Edit the source of the section
Find the comment you're trying to reply to
Put the right number of ::'s next to it
Place a {{ping|username you're replying to}} before your reply
Write the reply
This process seems rather arduous for simply replying to a talk page comment and letting the user you're replying to know you replied.
Yo, could anyone help me out by creating a (hopefully simple) script?
Every diff page has "← Previous edit" and "Next edit →" links. I'd like each of those to be followed by a "(diff only)" link, which would point to the same URL, but with the additional parameter &diffonly=1.
I have used it all the time since I wrote it. There are some bugs with duplicate parameters in the url sometimes, but it still works fine. Makes cruising through diffs on long pages a breeze. HighInBC(was Chillum)23:05, 27 September 2015 (UTC)
@Scott and HighInBC: I saw that this script was using addOnloadHook, which is deprecated and will be removed from MediaWiki sooner or later, so I had a go at turning it into a proper gadget. You can find it at User:Mr. Stradivarius/gadgets/DiffOnly.js. And of course, while I was at it I had to fix the duplicate URL parameter bug and make the arrow always appear in the right place. :) Try it out and let me if you think the interface needs tweaking. — Mr. Stradivarius♪ talk ♪10:39, 28 September 2015 (UTC)
Much better. I only left it as it was because it was not broken enough to fix, but now that it is fixed I love it. Before I would manually remove the diff_only from the uri, now you can click out proper. People should use your version for sure. HighInBC(was Chillum)15:06, 28 September 2015 (UTC)
Give out Deletion to Quality Awards and log at Hall of Fame
Could "Close XfD" be extended with another script to close WP:NFCR threads (and possibly other discussions)? Maybe such a function exists already, and I don't see it in the script lists. Similar to other XfD scripts, it would have to add 1) {{subst:archive top|INSERT REASON HERE. --~~~~}} below the section header and 2) {{subst:archive bottom}} after the thread. If the function already exists, just point me in the right direction please :). Thank you. GermanJoe (talk) 22:28, 29 September 2015 (UTC)
hello. I'm not sure if this is the right place to ask, but I'm gonna ask anyways. Can someone (who is way smarter than I am) create a script for SVG editing? Possibly even just copy the one over from Commons (User:Rillke/SVGedit.js, handled by User:Rillke/MwJSBot.js). I work on university articles and their sub articles, many of which have a vector image, and I cannot update the colors due to me not having a program nor wanting one. User:Rillke/SVGedit.js is a tremendous help on the Commons for me, mainly because I just update the colors. Please let me know if I need to request somewhere else or if someone can create this script. Thanks. 🇺🇸 Corkythehornetfan 🇺🇸 22:10, 16 February 2016 (UTC)
If that script does what you want to do here, just add mw.loader.load( "https://commons.wikimedia.org/w/index.php?title=User:Rillke/SVGedit.js&action=raw&ctype=text/javascript" ); to your common.js to import it.
Thanks! It looks like I'll have to add it to the global page. Not that smart when it comes to this stuff, so I'll have to try and figure it out! 🇺🇸 Corkythehornetfan 🇺🇸 04:40, 17 February 2016 (UTC)
As of just now, you've added code to your global.js page at meta that shouldn't be there. Much of it is for adding and configuring the extension to and in a MediaWiki installation; it's already added to meta. The only code you should have in you global.js (to enable the specific script in question) is mw.loader.load( "https://commons.wikimedia.org/w/index.php?title=User:Rillke/SVGedit.js&action=raw&ctype=text/javascript" );.
Assuming you added the other code because the first try didn't work, it is possible the script is written too specifically for commons. In that case, it might need to be rewritten (a little) for other sites. In that case, it might prove most efficient to talk to the developer. fredgandt06:00, 17 February 2016 (UTC)
Thanks for your help! I appreciate it! I've replaced it with that single code, and it still doesn't work. Just on Commons. I've tried to talking with the user, but haven't gotten a response. Thoughts on what to do? 🇺🇸 Corkythehornetfan 🇺🇸 19:22, 18 February 2016 (UTC)
Aside from waiting a little while for the response (patience is a virtue ;-), I don't mind taking a look, but it won't be tonight. I've already tested the global.js which works as expected, so there's likely an incompatibility with something specifically different here than there, which should be relatively minor (since all the WMF sites are basically the same (MW)). If nobody else feels like jumping in here in the meantime, I'll get back to you as soon as I'm able (a few days at most). fredgandt21:40, 18 February 2016 (UTC)
Thanks... Patience is one thing I do not have! lol That user has done editing since I posted there and has likely seen it... but then again, maybe they haven't. I don't need it right now, so y'all can take your time. Thanks, 🇺🇸 Corkythehornetfan 🇺🇸 21:48, 18 February 2016 (UTC)
The script at commons utilises dependencies which aren't available here. <--- bad news :-(
It's thus not trivial to get working here. <--- more bad news :-C
There's theoretically no reason it can't be rewritten specifically for Wikipedia. <--- good news :-)
Not by me and time soon. <--- On balance, this isn't terrible news :-|
There's an experimental SVG editing MediaWiki extension, which might be just the thing to loudly support being developed to a stable version and included here, but that could take years. In the meantime, the general policy is to migrate files that are used on this Wiki to commons where possible. Bearing that in mind, there should be few SVGs which aren't editable on commons, and it's likely that the few which aren't, shouldn't be edited anyway.
Can you provide an example of an SVG file here which you'd like to edit using this kind of script? If there's any chance of building a script for this functionality, I (or anyone else considering it) will need an example of what it will be acting on. This would be an SVG file here, that isn't at commons and can't be (for whatever reason). fredgandt17:55, 20 February 2016 (UTC)
If all else fails, SVG files are just text. It'll take a little patience and trial-and-error but it's quite straightforward to change a colour using a text editor. Bazj (talk) 18:42, 20 February 2016 (UTC)
One non-free file I specifically talking about was File:Florida Gators logo.svg. It was at the Graphics Lab/Illustration workshop for a couple of weeks, but someone finally updated it the other day. Another file (if it was the correct logo) would be File:TCU Horned Frogs Logo.svg. The purple would need updated to #4d1979 per Page 7 of the brand guidelines. There are many other non-free logos (university seals, logos, athletic logos, etc.) out there that could use color updating (I don't know any off the top of my head. I have found some SVG files that were in the PD that were on here that I've transferred to Commons to update the colors that way. (File:Florida Gators script logo.svg)
I do have TextEdit on my MacBook Pro, but currently I cannot save SVG files on my computer. If this would be the best way to go about this, please let me know how to save svg files to the computer. Thanks for looking into it! 🇺🇸 Corkythehornetfan 🇺🇸 00:54, 21 February 2016 (UTC)
At File:Florida Gators logo.svg click on the "Original file" link, just below the image. That'll give you the svg file in a window on it's own. Then save the image - the window is the image on it's own so it should just save without any fancy tricks. I used Inkscape to find out which element was which 'til I found the colour in question was 0021a5. Now that I've done that I can see it's just as easily found by searching for "fill:#". In a text editor change all occurrences of 0021a5 to 4d1979 , save file, re-upload, hey presto! I've not uploaded, you can do it for yourself, take the credit and the learning experience.
A word of caution, the file was edited just 2 days ago with a claim that theirs are the "official" colours. Regards, Bazj (talk) 10:56, 21 February 2016 (UTC)
For my own amusement, I am interested in giving it a go Corky. I'll let you know if I have any success; don't hold your breath ;-) fredgandt16:11, 21 February 2016 (UTC)
Oh, please do... If I could I do it on here instead of textedit, that'd be even better! Best of luck! 🇺🇸 Corkythehornetfan 🇺🇸 00:35, 22 February 2016 (UTC)
Guide talks that "the best and most recommended way" to debug a script are put in common.js string like: mw.loader.load( 'http://localhost/script.js' );. But it dont works, and give the error in browser console :
Hi everyone, I need some help with this js page, wich I create to test if I can get the gadget for adding translations, much as this template it has, but something doesn't work. I test it here, but I don't get the gadet below the template trans-top. Am I doing something wrong? -- DenisWasRight (talk) 12:21, 24 May 2016 (UTC)
You don't need "some" help here, you need a lot of help. That script, which I wrote, and you copied without attributing it to me or giving the original URL, won't work there, it uses lua modules, etc. --V111P (talk) 22:08, 25 May 2016 (UTC)
I for sure know that, but it is an experiment. When it's finished I should give the right name (dont worry). But for now it's standing om my personal page. Btw I'm almost there, so this can be archived. -- DenisWasRight (talk) 08:39, 26 May 2016 (UTC)
Hello, can somebody tells me why does this Script not support the Cyrillic script. It's used by this template, but when I type something in Cyrillic by clicking on ± a messege "Glosses should be unique" shows up. -- DenisWasRight (talk) 11:35, 21 July 2016 (UTC)
GA Reviewer Idea
I've recently thought about an idea for a script similar to AFCH, just with good articles. I believe this will probably be kinda hard, so I won't be surprised if nobody picks up on this. Pinging MusikAnimal and Samtar because they're the only coders that I know. Dat GuyTalkContribs12:42, 7 August 2016 (UTC)
@DatGuy: All you have to do to nominate an article is add the nomination template to the talk page, and a bot does the rest. Review pages are easily created with the "start review" links, once a reviewer is ready to start the review. Since, unlike AFC, neither nominating nor reviewing should be done in bulk, it hardly seems worth coding for these actions. - Evad37[talk]02:44, 8 August 2016 (UTC)
A script would be nice for these two things only: In the Passing section of WP:GAI#Step_4:_Finishing_the_review, Step 3 and also Step 6. Other than that, much of the GA process is already automated. It is probably one of the smoothest-running automated systems on Wikipedia. Considering that the two most difficult tasks of a GA review is preparing the article for nomination and actually performing the review, neither of which can be automated, doing the few steps at WP:GAI#Step_4:_Finishing_the_review is a cinch for a human editor. Although, it would be nice if the human could push a button to do Step 3 and run another script to do Step 6. Otherwise, we're fine. —Prhartcom♥03:05, 10 August 2016 (UTC)
Thanks for your feedback Prhartcom. #6 looks a bit tricky for a script, but I think I have an idea of how it could be done. While it could be just a separate script for doing step #6, a "one click button" approach that does steps 1 to 4 as well seems more streamlined, and not that much harder to code. - Evad37[talk]03:33, 11 August 2016 (UTC)
I actually am not in favor of automating that. It is already so simple: The editor pastes in their template and fills in a couple of variables, then existing automation takes over. It is the same action that is all over Wikipedia. Automation is simply not needed here (except for possibly the two areas I mentioned). —Prhartcom♥21:55, 11 August 2016 (UTC)
Regex or user script for simplifying piped links of mixed case
I have recently noticed that Wikipedias imported from the Incubator (e.g., ady:, tcy:) have had links like:
[[Wp/xyz/Foo|Foo]]
(where "xyz" is the language code used in the test wiki in question) automatically changed to:
[[Foo|Foo]]
during the importing process. Obviously, it would be better to convert such links "all the way" to:
[[Foo]]
since the third link is functionally equivalent to the second but uses smaller/simpler wikicode (and is less likely to confuse new editors).
Twoimporters I have asked about this have said (essentially) that they would look into possibly making such conversions during future imports.
In the meantime, I have tried out various available "cleanup scripts" to fix such links in wikis that have already been moved from the Incubator. So far, the one that seems to work best (for me) is TMg's autoFormatter script. It will convert the second (redundantly-piped) link above into the third (unpiped) — plus, it provides a "hook" for user-defined replacements. Unfortunately, that script doesn't catch things like:
[[Адыгэхэр|адыгэхэр]]
where the link target is capitalized and the link text is not (but they are otherwise equivalent). I have also tried AutoEd and wikiEd and, unless I am very much mistaken, neither does what I want.
So, then I tried to come up with a regex I could add to my common.js (on various non-English Wikipedias) to make such substutitions with autoFormatter. Unfortunately, I have not found one that works.
Note that the "obvious" substitution:
/\[\[([^\n:[\]|]+)\|(\1)\]\]/gi, '[[$2]]'
is not acceptable, since it would also try to change something like:
[[Адыгэ университетыр|Адыгэ Университетыр]]
which should remain piped.
What I need is a regex substitution that works in common.js, works for any script [written language] where case is meaningful, allows for a difference in case only on the first character, and preserves the link text (not the link target).
With my modest regex experience (in Perl), I have tried:
but none of them worked (the editor complained about the last one being invalid even before I saved the code — presumably the other two are valid syntax, but either I'm using \l and \u wrong or that feature isn't supported in common.js).
Am I just overlooking something obvious here? Can anyone see what I'm doing wrong and fix any of these example substitutions? Alternatively, is there a user script that already makes these kinds of fixes outside of enwiki? - dcljr (talk) 09:48, 24 August 2016 (UTC) — Or even inside enwiki (so I can see the regex they're using)? - dcljr (talk) 10:07, 24 August 2016 (UTC)
@Dcljr:\l and \u aren't supported in JavaScript regex - see the JavaScript regex docs for a list of valid special tokens. Really for something like this you need a wikitext parser, not a regex, although a simplified parser should do the job just fine. Does it need to be in JavaScript? Otherwise it might be worth checking out Wikipedia:WikiProject Check Wikipedia, as fixing those kinds of piped links are exactly the kinds of things that they are interested in. I think AWB and WikiCleaner might be able to do the job, but neither of those are written in JavaScript. How does the importing work, by the way? Fixing the import tool seems like the most logical way to go about this. — Mr. Stradivarius♪ talk ♪13:13, 25 August 2016 (UTC)
Dcljr Check Wikipedia error#64 does look for these cases. Both AWB and WikiCleaner do fix the piped link issue. autoFormatter and AutoEd also do fix it and they are written in JavaScript. autoFormatter probably has cleaner code. The maintainer is very good at answering questions and is a regex master. Bgwhite (talk) 21:21, 25 August 2016 (UTC)
Unfortunately, as I said, neither autoFormatter nor AutoEd find cases where the link target and link text differ in case on the first character, and none of the hits listed at error#64 show that, so I kinda doubt WikiCleaner does it either (I'm looking into it). The Javascript requirement is just because I'm on Linux (so, no AWB — and I'm not going to try Windows emulation just for this). Thanks for the mozilla.org link, BTW. Too bad JS regex is so limited. I agree that fixing the importing tool is the way to go, but one importer said, "I don't know a regular expression to fix this" (so, presumably that means the importer fix would have to be based on a regex?). I don't know anything about how importing works. (Note: I originally linked to the wrong wiki when I mentioned the "Twoimporters" above — this has now been fixed.) - dcljr (talk) 04:10, 26 August 2016 (UTC)
BTW, the author of autoFormatter has already been asked about this by someone else. Doesn't seem like he wants to implement it. (In light of my experience, I'm not sure he could implement it even if he wanted to. I have directed him to this thread, so we'll see what he says.) - dcljr (talk) 04:16, 26 August 2016 (UTC)
Dcljr CheckWiki does find cases of [[Адыгэхэр|адыгэхэр]]. AWB and WPCleaner also fixes these cases. All three work with Cyrillic text. AutoEd also does fix this case. For Checkwiki, I make the first letter (А & а) uppercase and check if they are equal. What you see on the Checkwiki page is all first letters uppercased. Bgwhite (talk) 05:06, 26 August 2016 (UTC)
Of course: the 2 tools that are hardest for me to use will do what I want... (But AutoEd did not fix this when I tried it on ady:Адыгэй, which is where the [[Адыгэхэр|адыгэхэр]] example actually comes from. Are you saying it works for you?) - dcljr (talk) 05:27, 26 August 2016 (UTC)
OK, both "complete" and "simple" AutoEd does what I want. I was trying to use just certain specific modules. Apparently I did something wrong. (I coulda sworn it did replace the links having the same case, just not the ones with mixed case! So I couldn't have done anything too wrong. Will look into getting AutoEd to work with only the modules I need.) - dcljr (talk) 05:35, 26 August 2016 (UTC) Thanks, Bgwhite! - dcljr (talk) 05:39, 26 August 2016 (UTC)
OK, verified AutoEd "formatter" mode does what I want ([[Адыгэхэр|адыгэхэр]] → [[адыгэхэр]], and does not change [[Адыгэ университетыр|Адыгэ Университетыр]]). Problem solved. Thanks, everyone. - dcljr (talk) 06:39, 26 August 2016 (UTC)
Guys, please ask the tool authors. How should we know? Here is a custom replacement that works with my Auto-Formatter. The main reason why I do not have this enabled by default is that not all wikis do have this feature enabled where the first character of a page title is case-insensitive. Hm, I guess I could add this rule anyway and enable it for English wikis only. --TMg19:12, 26 August 2016 (UTC)
Thanks for the code. If you do add this to your script, I would recommend (/humbly request, as I have done elsewhere) using a configuration variable to allow users to enable it or not, depending on whether it is appropriate on the particular wiki they're working on. (After all, this is useful far beyond English wikis.) Seems like that would be the only reasonable choice given the lack (AFAIK) of a central list of which wikis have and don't have initial-case-sensitivity. (The variable "wgCapitalLinks" in InitialiseSettings.php claims only jbowiki and [all] Wiktionaries have it, but both this and a "wgCapitalLinkOverrides" for per-namespace settings can be set in an individual wiki's LocalSettings.php, which would not be publicly viewable, so who knows which other wikis have it… Does anyone know which other wikis have it?) - dcljr (talk) 13:40, 27 August 2016 (UTC)
A bunch of welcome templates link to the defunct User Script Wikiproject instead of here
I wouldn't recommend it, that's tedious work you're talking about there. Maybe doing a few highly visible pages or used templates but don't spend more than a few minutes on it. Wikipedia:WikiProject User scripts has a message box saying to Wikipedia:User scripts instead, so that's more than enough. Or even better: turn it into a redirect pointing to this page. Ugog Nizdast (talk) 09:16, 3 September 2016 (UTC)
Someone else has already gone ahead and updated them. I was mostly concerned with server issues since I don't know the extant to which these templates are used and if changing them all at once would put a strain on the servers. M. A. Bruhn (talk) 22:07, 3 September 2016 (UTC)