|
|
5번째 줄: |
5번째 줄: |
| kill_uncy_jsonEdit(); | | kill_uncy_jsonEdit(); |
| /* [[틀:JSON수정]] 차단 끝 */ | | /* [[틀:JSON수정]] 차단 끝 */ |
|
| |
| /* 모바일용 개발자 도구 실행 버튼 만들기 */
| |
| // function startFirebug() {
| |
| // mw.loader.load('/index.php?title=사용자:hsl0/firebug.js&action=raw&ctype=text/javascript');
| |
| // }
| |
| // function startEruda() {
| |
| // mw.loader.load('/index.php?title=사용자:hsl0/eruda.js&action=raw&ctype=text/javascript');
| |
| // }
| |
| // function createDevToolsButton() {
| |
| // $('#footer-places')
| |
| // //.append($('<li id="footer-places-devtools-firebug" />').append($('<a>개발자 도구(Firebug)</a>').click(startFirebug)))
| |
| // .append($('<li id="footer-places-devtools-eruda" />').append($('<a>개발자 도구</a>').click(startEruda)));
| |
| // }
| |
| // $(createDevToolsButton);
| |
|
| |
|
| function testHook(name) { | | function testHook(name) { |
38번째 줄: |
24번째 줄: |
| testHook('wikipage.editform'); | | testHook('wikipage.editform'); |
| testHook('wikipage.indicators'); | | testHook('wikipage.indicators'); |
|
| |
|
| |
|
| |
| /** 플러그인 p21***************************
| |
| * 블랙잭
| |
| * 버전 => 0.840a4
| |
| * 작성자 : [[사용자:Riemann|Riemann]]
| |
| * JSON => p21 = {"name":"p21","descript":"블랙잭","version":"0.840a4","local":true,"creat":"Riemann","state":"사용자:Riemann/p21","executable":true};
| |
| */
| |
| function plugin_p21(){
| |
| if($("[data-name='p21']").length >= 1){
| |
| var title = mw.config.get('wgPageName');
| |
| if (title.slice( 1, 2 ) == "라") {
| |
| var blind = true;
| |
| var defa = 20;
| |
| } else {
| |
| var blind = false;
| |
| var defa = 10;
| |
| }
| |
| var mult = defa;
| |
| $("#multiplier").text(mult);
| |
|
| |
| var coins = 100;
| |
| var wincount = 0;
| |
| var losecount = 0;
| |
| //$("#console").text("스코어: " + coins + "점");
| |
| $("#console").text("스코어: " + wincount + "승 " + losecount + "패");
| |
| $("#console").append("\n블랙잭에 오신 것을 환영합니다.");
| |
|
| |
| const pcLst = [
| |
| 0xA1,0xA2,0xA3,0xA4,0xA5,0xA6,0xA7,0xA8,0xA9,0xAA,0xAB,0xAD,0xAE,
| |
| 0xB1,0xB2,0xB3,0xB4,0xB5,0xB6,0xB7,0xB8,0xB9,0xBA,0xBB,0xBD,0xBE,
| |
| 0xC1,0xC2,0xC3,0xC4,0xC5,0xC6,0xC7,0xC8,0xC9,0xCA,0xCB,0xCD,0xCE,
| |
| 0xD1,0xD2,0xD3,0xD4,0xD5,0xD6,0xD7,0xD8,0xD9,0xDA,0xDB,0xDD,0xDE];
| |
| const pointData = {a1:1,a2:2,a3:3,a4:4,a5:5,a6:6,a7:7,a8:8,a9:9,aa:10,ab:10,ad:10,ae:10,b1:1,b2:2,b3:3,b4:4,b5:5,b6:6,b7:7,b8:8,b9:9,ba:10,bb:10,bd:10,be:10,c1:1,c2:2,c3:3,c4:4,c5:5,c6:6,c7:7,c8:8,c9:9,ca:10,cb:10,cd:10,ce:10,d1:1,d2:2,d3:3,d4:4,d5:5,d6:6,d7:7,d8:8,d9:9,da:10,db:10,dd:10,de:10};
| |
| var pcSet = [];
| |
| function hexToChar(x) {
| |
| return String.fromCharCode(0xD83C) +String.fromCharCode(x + 0xDC00);
| |
| }
| |
| function hexToStr(x) {
| |
| return x.toString(16);
| |
| }
| |
| var dealerD, guestD;
| |
| $("#deal").click(function(){
| |
| //$("#console").text("스코어: " + coins + "점");
| |
| $("#console").text("스코어: " + wincount + "승 " + losecount + "패");
| |
| $("#console").append("\n새 판을 엽니다.");
| |
| $("#deal").css("display", "none");
| |
| $("#dealerDeck").text("");
| |
| $("#guestDeck").text("");
| |
| pcSet = Object.create(pcLst);
| |
| deal();
| |
| return 0;
| |
| });
| |
| $("#hit").click(function(){
| |
| hit();
| |
| return 0;
| |
| });
| |
| $("#stand").click(function(){
| |
| stand();
| |
| return 0;
| |
| });
| |
| $("#surrender").click(function(){
| |
| surrender();
| |
| return 0;
| |
| });
| |
| $("#plus").click(function(){
| |
| inc();
| |
| return 0;
| |
| });
| |
| $("#minus").click(function(){
| |
| dec();
| |
| return 0;
| |
| });
| |
| $("#reset").click(function(){
| |
| reset();
| |
| return 0;
| |
| });
| |
| function reset() {
| |
| mult = defa;
| |
| $("#multiplier").text(mult);
| |
| }
| |
|
| |
| /*
| |
| function inc() {
| |
| if (mult < 100) {
| |
| mult += 2;
| |
| } else {
| |
| alert("최대 100 코인까지만 걸 수 있습니다.");
| |
| }
| |
| $("#multiplier").text(mult);
| |
| }
| |
|
| |
| function dec() {
| |
| if (mult > 2) {
| |
| mult -= 2;
| |
| } else {
| |
| alert("설마 빚을 판돈으로 거시려고요?");
| |
| }
| |
| $("#multiplier").text(mult);
| |
| }
| |
| */
| |
|
| |
| function deal() {
| |
| dealerD = [];
| |
| guestD = [];
| |
| dealerD.push(cardPop());
| |
| guestD.push(cardPop());
| |
| dealerD.push(cardPop());
| |
| guestD.push(cardPop());
| |
| if (blind == true) {
| |
| $("#dealerDeck").text("\u{1F0A0}\u{1F0A0}");
| |
| } else {
| |
| $("#dealerDeck").text(hexToChar(dealerD[0]) + "\u{1F0A0}");
| |
| }
| |
| $("#dealerS").text("?");
| |
| if (blind == true) {
| |
| $("#guestDeck").text("\u{1F0A0}\u{1F0A0}");
| |
| } else {
| |
| $("#guestDeck").text(hexToChar(guestD[0]) + hexToChar(guestD[1]));
| |
| }
| |
| var guestScore = [];
| |
| var score = pointData[hexToStr(guestD[0])] + pointData[hexToStr(guestD[1])];
| |
| $("#guestS").text(score);
| |
| if ((pointData[hexToStr(guestD[0])] == 1 && pointData[hexToStr(guestD[1])] == 10) || (pointData[hexToStr(guestD[0])] == 10 && pointData[hexToStr(guestD[1])] == 1)) {
| |
| $("#guestS").text(21);
| |
| jack();
| |
| } else {
| |
| $("#hit").css("display", "inline-flex");
| |
| $("#stand").css("display", "inline-flex");
| |
| $("#surrender").css("display", "inline-flex");
| |
| }
| |
| };
| |
| function hit() {
| |
| $("#hit").css("display", "none");
| |
| $("#stand").css("display", "none");
| |
| $("#surrender").css("display", "none");
| |
| guestD.push(cardPop());
| |
| var guestDeq = "";
| |
| for (i = 0; i < guestD.length; i++) {
| |
| guestDeq += hexToChar(guestD[i]);
| |
| }
| |
| if (blind == true) {
| |
| $("#guestDeck").text("\u{1F0A0}".repeat(guestDeq.length / 2));
| |
| } else {
| |
| $("#guestDeck").text(guestDeq);
| |
| }
| |
| var guestScore = [];
| |
| var score = 0;
| |
| for (i = 0; i < guestD.length; i++) {
| |
| guestScore.push(pointData[hexToStr(guestD[i])]);
| |
| score += guestScore[i];
| |
| }
| |
| $("#guestS").text(score);
| |
| if (score == 21 || (score == 11 && guestScore.includes(1))) {
| |
| $("#console").append("\n21점이므로 자동으로 스탠드를 외쳤습니다.")
| |
| stand(dealerD,guestD);
| |
| } else if (score > 21) {
| |
| bust();
| |
| } else {
| |
| $("#hit").css("display", "inline-flex");
| |
| $("#stand").css("display", "inline-flex");
| |
| }
| |
| return 0;
| |
| }
| |
| function stand() {
| |
| $("#hit").css("display", "none");
| |
| $("#stand").css("display", "none");
| |
| $("#surrender").css("display", "none");
| |
| var dScore = 0;
| |
| var dealerScore = []
| |
| for (i = 0; i < dealerD.length; i++) {
| |
| dealerScore.push(pointData[hexToStr(dealerD[i])]);
| |
| dScore += dealerScore[i];
| |
| }
| |
| while (dScore < 17) {
| |
| dealerD.push(cardPop());
| |
| $("#console").append("\n딜러가 카드를 뽑았습니다.")
| |
| dealerScore = [];
| |
| dScore = 0;
| |
| for (i = 0; i < dealerD.length; i++) {
| |
| dealerScore.push(pointData[hexToStr(dealerD[i])]);
| |
| dScore += dealerScore[i];
| |
| dealerDeq += hexToChar(dealerD[i]);
| |
| }
| |
| }
| |
| var dealerDeq = "";
| |
| for (i = 0; i < dealerD.length; i++) {
| |
| dealerDeq += hexToChar(dealerD[i]);
| |
| }
| |
| $("#dealerS").text(dScore);
| |
| $("#dealerDeck").text(dealerDeq);
| |
| guestScore = [];
| |
| score = 0;
| |
| for (i = 0; i < guestD.length; i++) {
| |
| guestScore.push(pointData[hexToStr(guestD[i])]);
| |
| score += guestScore[i];
| |
| }
| |
| $("#guestS").text(score);
| |
| if (score > 21) {
| |
| bust()
| |
| } else if (dScore > 21) {
| |
| $("#console").append("\n딜러의 버스트.")
| |
| win()
| |
| } else {
| |
| $("#console").append("\n딜러의 스탠드.")
| |
| compare(dealerD,guestD);
| |
| }
| |
| return 0;
| |
| }
| |
| function compare() {
| |
| var dealerScore = [];
| |
| var dScore = 0;
| |
| for (i = 0; i < dealerD.length; i++) {
| |
| dealerScore.push(pointData[hexToStr(dealerD[i])]);
| |
| dScore += dealerScore[i];
| |
| }
| |
| var guestScore = [];
| |
| var score = 0;
| |
| for (i = 0; i < guestD.length; i++) {
| |
| guestScore.push(pointData[hexToStr(guestD[i])]);
| |
| score += guestScore[i];
| |
| }
| |
| if (dScore < 12 && dealerScore.includes(1)) {
| |
| dScore += 10
| |
| }
| |
| if (score < 12 && guestScore.includes(1)) {
| |
| score += 10
| |
| }
| |
| $("#dealerS").text(dScore);
| |
| $("#guestS").text(score);
| |
| if (dScore > score) {
| |
| lose()
| |
| } else if (dScore == score) {
| |
| push()
| |
| } else {
| |
| win()
| |
| }
| |
| return 0;
| |
| }
| |
| function win() {
| |
| $("#console").append("\n축하합니다! 이겼습니다.")
| |
| //$("#console").append("\n" + mult + "점을 얻었습니다.")
| |
| //coins += mult;
| |
| wincount += 1;
| |
| $("#deal").css("display", "inline-flex");
| |
| return 0;
| |
| }
| |
| function lose() {
| |
| $("#console").append("\n졌습니다...")
| |
| //$("#console").append("\n" + mult + "점을 잃었습니다.")
| |
| //coins -= mult;
| |
| losecount += 1;
| |
| $("#deal").css("display", "inline-flex");
| |
| publicAd();
| |
| return 0;
| |
| }
| |
| function push() {
| |
| $("#console").append("\n비겼습니다.")
| |
| $("#deal").css("display", "inline-flex");
| |
| return 0;
| |
| }
| |
| function surrender() {
| |
| $("#hit").css("display", "none");
| |
| $("#stand").css("display", "none");
| |
| $("#surrender").css("display", "none");
| |
| $("#console").append("\n이번 판을 포기하셨습니다 (패배로 처리됩니다).")
| |
| //$("#console").append("\n" + (0.5 * mult) + "점을 잃었습니다.")
| |
| //coins -= 0.5 * mult;
| |
| losecount += 1;
| |
| $("#deal").css("display", "inline-flex");
| |
| publicAd();
| |
| return 0;
| |
| }
| |
| function bust() {
| |
| $("#console").append("\n버스트! 유감입니다. 졌습니다...")
| |
| //$("#console").append("\n" + mult + "점을 잃었습니다.")
| |
| //coins -= mult;
| |
| losecount += 1;
| |
| $("#hit").css("display", "none");
| |
| $("#stand").css("display", "none");
| |
| $("#deal").css("display", "inline-flex");
| |
| publicAd();
| |
| return 0;
| |
| }
| |
| function jack() {
| |
| $("#console").append("\n블랙잭 달성! 축하합니다. 이겼습니다!")
| |
| //$("#console").append("\n" + (1.5 * mult) + "점을 획득했습니다.")
| |
| //coins += 1.5 * mult;
| |
| wincount += 1;
| |
| $("#deal").css("display", "inline-flex");
| |
| return 0;
| |
| }
| |
| function publicAd() {
| |
| if (coins < 0) {
| |
| $("#notice").text("땀 흘려 번 돈이 아름답습니다.");
| |
| }
| |
| return 0;
| |
| }
| |
| function cardPop() {
| |
| var j, ret;
| |
| j = Math.floor(Math.random() * pcSet.length);
| |
| ret = pcSet[j];
| |
| pcSet.splice(j,1);
| |
| return ret;
| |
| }
| |
|
| |
|
| |
| }
| |
|
| |
| }
| |
| $( plugin_p21 );
| |
| /* p21 끝 */
| |
|
| |
| /** 플러그인 real369***************************
| |
| * real369 플레이
| |
| * 버전 => 1.1.7
| |
| * 작성자 : [[사용자:BANIP|BANIP]]
| |
| * JSON => real369 = {"name":"real369","descript":"real369 플레이","version":"1.1.7","local":true,"creat":"BANIP","state":"Real 369/플러그인","executable":true};
| |
| */
| |
| function plugin_real369(){
| |
| if($("[data-name='real369']").length >= 1){
| |
| /**
| |
| * 지금 박수를 쳐야되는지 숫자를 외쳐야 하는지 알아 냅니다
| |
| * @param {number} number 지금 순서가 몇번째인지 넣는 칸.
| |
| * @return {number|Array[number]} 박수를 쳐야되는 상황이면 배열 안에 숫자를 담아 반환하고 아니면 파라미터를 반환.
| |
| */
| |
| function getAnswer(number) {
| |
| var rawNumber = number + "";
| |
| var targetNumber = rawNumber.replace(/3|6|9/g, "");
| |
| var diff = rawNumber.length - targetNumber.length;
| |
| if (diff === 0)
| |
| return number + "";
| |
| else
| |
| return "짝!".repeat(diff);
| |
| }
| |
| function isMobile() {
| |
| return !(navigator.userAgent.match(/Android|iPhone|iPad|iPod/i) === null);
| |
| }
| |
| var GUI = /** @class */ (function () {
| |
| function GUI() {
| |
| this.domList = {
| |
| retry: document.querySelector("#gamewrap .gamelink .retry"),
| |
| answer: document.querySelector("#gamewrap .answer"),
| |
| dialog: document.querySelector("#gamewrap .dialog"),
| |
| progress: document.querySelector("#gamewrap .progress"),
| |
| gamelink: document.querySelector("#gamewrap .gamelink")
| |
| };
| |
| this.bindOtherEvent();
| |
| //this.start();
| |
| }
| |
| GUI.prototype.start = function () {
| |
| this.domList.answer.innerHTML = "시작!";
| |
| this.domList.dialog.innerHTML = "";
| |
| this.domList.gamelink.style.display = "none";
| |
| createGame(gui);
| |
| input.setGame(game);
| |
| };
| |
| GUI.prototype.bindOtherEvent = function () {
| |
| var _this = this;
| |
| this.domList.retry.addEventListener("click", function () {
| |
| if (game !== null)
| |
| game.gameOver();
| |
| _this.start();
| |
| });
| |
| };
| |
| GUI.prototype.message = function (message) {
| |
| var dialogNode = this.domList.dialog;
| |
| var messageNode = document.createElement("li");
| |
| messageNode.innerHTML = message;
| |
| dialogNode.appendChild(messageNode);
| |
| dialogNode.scrollTop = dialogNode.scrollHeight;
| |
| };
| |
| GUI.prototype.initOrder = function (userCount, startUser) {
| |
| var orderStringCount = 8;
| |
| var orderString = new Array(orderStringCount).fill("1")
| |
| .map(function (v, i) { return (startUser + i) % userCount === 0 ? username : "COM" + (startUser + i) % userCount; })
| |
| .join(" => ");
| |
| this.message("게임이 시작되었습니다!!!");
| |
| this.message("게임순서 : " + orderString + "...");
| |
| };
| |
| GUI.prototype.getProgressColor = function (progress) {
| |
| var interval = [30, 60, 100];
| |
| var color = ["green", "yellow", "red"];
| |
| var index = interval.indexOf(interval.filter(function (v) { return v > progress; })[0]);
| |
| return color[index];
| |
| };
| |
| GUI.prototype.resetTime = function (duration) {
| |
| var _this = this;
| |
| clearInterval(this.timerInterval);
| |
| var startTime = Date.now();
| |
| this.timerInterval = setInterval(function () {
| |
| var now = Date.now();
| |
| var progress = (now - startTime) / duration * 100 - 1;
| |
| var progressColor = _this.getProgressColor(progress);
| |
| _this.domList.progress.style.background = "linear-gradient(to right," + progressColor + " " + (100 - progress) + "%,white " + (100 - progress + 0.1) + "%)";
| |
| }, 10);
| |
| };
| |
| GUI.prototype.setEnemyTurn = function (order) {
| |
| this.nextUser = "COM" + order;
| |
| };
| |
| GUI.prototype.setMyTurn = function () {
| |
| this.nextUser = username;
| |
| };
| |
| GUI.prototype.gameOver = function (reason, lastCount) {
| |
| this.domList.answer.innerHTML = reason;
| |
| this.message("게임이 끝났습니다!!");
| |
| this.message("최종 카운트: " + lastCount);
| |
| input.setGame(null);
| |
| this.domList.gamelink.style.display = "block";
| |
| clearInterval(this.timerInterval);
| |
| };
| |
| GUI.prototype.setNumber = function (number) {
| |
| this.domList.answer.innerHTML = number;
| |
| };
| |
| GUI.prototype.sayNumber = function (number, name) {
| |
| if (name === void 0) { name = this.nextUser; }
| |
| this.message(name + " : " + number);
| |
| };
| |
| GUI.prototype.setHandClab = function (clab) {
| |
| this.domList.answer.innerHTML = clab;
| |
| };
| |
| return GUI;
| |
| }());
| |
| var Game = /** @class */ (function () {
| |
| function Game(gui, playerCount, time) {
| |
| if (playerCount === void 0) { playerCount = 3; }
| |
| if (time === void 0) { time = 1000; }
| |
| this.gui = gui;
| |
| this.playerCount = playerCount;
| |
| this.time = time;
| |
| this.order = Math.floor(Math.random() * playerCount);
| |
| this.number = 1;
| |
| gui.initOrder(playerCount, this.order);
| |
| this.turnStart();
| |
| }
| |
| Game.prototype.next = function () {
| |
| var prevNumber = getAnswer(Number(this.number));
| |
| this.gui.sayNumber(prevNumber);
| |
| this.order = (this.order + 1) % this.playerCount;
| |
| this.handClab = "";
| |
| this.number++;
| |
| this.turnStart();
| |
| };
| |
| Game.prototype.turnStart = function () {
| |
| this.gui.resetTime(this.time);
| |
| if (this.order === 0)
| |
| this.myTurn();
| |
| else
| |
| this.enemyTurn();
| |
| };
| |
| Game.prototype.enemyTurn = function () {
| |
| var _this = this;
| |
| this.gui.setEnemyTurn(this.order);
| |
| this.turnTimeout = setTimeout(function () {
| |
| _this.shortenTime();
| |
| _this.next();
| |
| }, this.time * Math.random());
| |
| };
| |
| Game.prototype.myTurn = function () {
| |
| var _this = this;
| |
| this.gui.setMyTurn();
| |
| this.turnTimeout = setTimeout(function () {
| |
| if (getAnswer(_this.number) === _this.handClab)
| |
| _this.next();
| |
| else
| |
| _this.gameOver("시간 초과!");
| |
| }, this.time);
| |
| };
| |
| Game.prototype.sayNumber = function (answer) {
| |
| clearTimeout(this.turnTimeout);
| |
| var reasonGameOver = null;
| |
| if (this.order > 0)
| |
| reasonGameOver = "내 차례가 아닌데 말해버림!";
| |
| else if (getAnswer(this.number) === answer)
| |
| null;
| |
| else
| |
| reasonGameOver = "오답!";
| |
| if (reasonGameOver === null)
| |
| this.next();
| |
| else {
| |
| gui.sayNumber(answer, username);
| |
| this.gameOver(reasonGameOver);
| |
| }
| |
| };
| |
| Game.prototype.setHandClab = function (clab) {
| |
| this.handClab = clab;
| |
| };
| |
| Game.prototype.gameOver = function (reason) {
| |
| clearTimeout(this.turnTimeout);
| |
| this.gui.gameOver(reason, this.number);
| |
| game = null;
| |
| };
| |
| Game.prototype.shortenTime = function () {
| |
| this.time *= 0.94;
| |
| };
| |
| return Game;
| |
| }());
| |
| var Input = /** @class */ (function () {
| |
| function Input(game, gui) {
| |
| this.game = game;
| |
| this.gui = gui;
| |
| this.clickEventType = isMobile() ? "touchstart" : "click";
| |
| this.resetNumber();
| |
| this.bindKeyBoardEvent();
| |
| this.bindKeyPadEvent();
| |
| }
| |
| Input.prototype.setGame = function (game) {
| |
| this.game = game;
| |
| };
| |
| Input.prototype.bindKeyBoardEvent = function () {
| |
| var _this = this;
| |
| document.addEventListener("keydown", function (e) {
| |
| var key = e.key;
| |
| if (["Enter", "Space"].some(function (v) { return v === key; }))
| |
| return _this.pressEnter();
| |
| else if (key === "BackSpace")
| |
| _this.number = _this.number.slice(0, -1);
| |
| else if (isNaN(parseInt(key)))
| |
| return;
| |
| else
| |
| _this.number += key;
| |
| _this.gui.setNumber(_this.number);
| |
| });
| |
| };
| |
| Input.prototype.bindKeyPadEvent = function () {
| |
| var _this = this;
| |
| document.querySelectorAll(".keypad .key").forEach(function (node) {
| |
| node.addEventListener(_this.clickEventType, function (e) {
| |
| e.preventDefault();
| |
| _this.number += e.target.dataset.num;
| |
| _this.gui.setNumber(_this.number);
| |
| });
| |
| });
| |
| document.querySelector(".keypad .enter").addEventListener(this.clickEventType, function (e) {
| |
| e.preventDefault();
| |
| _this.pressEnter();
| |
| });
| |
| document.querySelector(".keypad .reset").addEventListener(this.clickEventType, function (e) {
| |
| e.preventDefault();
| |
| _this.resetNumber();
| |
| _this.gui.setNumber(_this.number);
| |
| });
| |
| };
| |
| Input.prototype.pressEnter = function () {
| |
| var _this = this;
| |
| if (game == null || game == undefined)
| |
| this.gui.message("아직 게임이 시작되지 않았어요.");
| |
| clearTimeout(this.enterTimeout);
| |
| if (this.number == "") {
| |
| this.enterCount++;
| |
| var answer_1 = "짝!".repeat(this.enterCount);
| |
| this.gui.setHandClab(answer_1);
| |
| this.game.setHandClab(answer_1);
| |
| this.enterTimeout = setTimeout(function () {
| |
| if (_this.game.order === 0) {
| |
| _this.game.sayNumber(answer_1);
| |
| }
| |
| _this.resetNumber();
| |
| }, 800);
| |
| }
| |
| else {
| |
| this.game.sayNumber(this.number);
| |
| this.resetNumber();
| |
| }
| |
| };
| |
| ;
| |
| Input.prototype.resetNumber = function () {
| |
| this.number = "";
| |
| this.enterCount = 0;
| |
| this.gui.setNumber(this.number);
| |
| };
| |
| return Input;
| |
| }());
| |
| var game = null;
| |
| var createGame = function (gui) { return game = new Game(gui, 4, 5000); };
| |
| var username = mw.config.values.wgUserName;
| |
| var gui = new GUI();
| |
| //createGame(gui);
| |
| var input = new Input(game, gui);
| |
|
| |
|
| |
| }
| |
|
| |
| }
| |
| $( plugin_real369 );
| |
| /* real369 끝 */
| |
|
| |
| /** 플러그인 msgame***************************
| |
| * 스톱워치 게임
| |
| * 버전 => 0.950
| |
| * 작성자 : [[사용자:Riemann|Riemann]]
| |
| * JSON => msgame = {"name":"msgame","descript":"스톱워치 게임","version":"0.950","local":true,"creat":"Riemann","state":"사용자:Riemann/msgame","executable":true};
| |
| */
| |
| function plugin_msgame(){
| |
| if($("[data-name='msgame']").length >= 1){
| |
| // 이부분에 코드 입력 //
| |
| sc = 0
| |
| cb = 0
| |
|
| |
| bl = false;
| |
| $(document.body).on("keydown", function(ev) {
| |
| if(ev.which == 13) {
| |
| if (bl == false) {
| |
| bl = true
| |
| startF();
| |
| } else {
| |
| bl = false
| |
| stopF();
| |
| }
| |
| }
| |
| });
| |
|
| |
| $("#msgame-start").on("click", function() {
| |
| bl = true
| |
| startF();
| |
| });
| |
|
| |
| $("#msgame-stop").on("click", function() {
| |
| bl = false
| |
| stopF();
| |
| });
| |
|
| |
| function startF() {
| |
| obj = Math.floor(Math.random() * 10) + 5;
| |
| $("#msgame-start").css("display", "none");
| |
| $("#msgame-stop").css("display", "block");
| |
| it = new Date();
| |
| si = setInterval(clockUpdate, 20)
| |
| $("#msgame-console").text(obj + " 초를 세세요.");
| |
| }
| |
|
| |
| function stopF() {
| |
| $("#msgame-clockText").css("display", "inline");
| |
| $("#msgame-stop").css("display", "none");
| |
| $("#msgame-start").css("display", "block");
| |
| clearInterval(si);
| |
| ie = new Date();
| |
| ifin = ie - it;
| |
| $("#msgame-clockText").text(toMilliSec(ifin));
| |
| finished(obj, ifin);
| |
| }
| |
|
| |
| function clockUpdate() {
| |
| ic = new Date();
| |
| id = ic - it;
| |
| ii = toMilliSec(id);
| |
| $("#msgame-clockText").text(ii);
| |
| if (obj * 1000 - id < 500 * cb && cb > 4 ) {
| |
| $("#msgame-clockText").fadeOut();
| |
| }
| |
| }
| |
|
| |
| function toMilliSec(d) {
| |
| return (Math.floor(d / 1000) + "\"" + ("" + d % 1000).padStart(3, "0")).padStart(6, "0");
| |
| }
| |
|
| |
| function finished(a, b) {
| |
| ath = a * 1000
| |
| if (ath == b) {
| |
| cbm = Math.floor(Math.pow(800, (1 + cb / 10)))
| |
| $("#msgame-console").text("정확하시군요. " + cbm + " 점 드리겠습니다.");
| |
| sc += cbm
| |
| cb += 1
| |
| } else if (Math.abs(ath - b) < 100) {
| |
| cbm = Math.floor(Math.pow((500 / Math.abs(ath - b)), (1 + cb / 10)))
| |
| $("#msgame-console").text("정확하시군요. " + cbm + " 점 드리겠습니다.");
| |
| sc += cbm
| |
| cb += 1
| |
| } else {
| |
| $("#msgame-console").text("안타깝습니다. 조금 더 노력해 보세요!");
| |
| cb = 0
| |
| }
| |
| $("#msgame-score").text(sc);
| |
| $("#msgame-combo").text(cb);
| |
| }
| |
| // 여기까지 코드 입력 //
| |
|
| |
|
| |
| }
| |
|
| |
| }
| |
| $( plugin_msgame );
| |
| /* msgame 끝 */
| |
|
| |
| /** 플러그인 numbase***************************
| |
| * 숫자야구 remake
| |
| * 버전 => 1.41
| |
| * 작성자 : [[사용자:Riemann|Riemann]]
| |
| * JSON => numbase = {"name":"numbase","descript":"숫자야구 remake","version":"1.41","local":true,"creat":"Riemann","state":"사용자:Riemann/numbase","executable":true};
| |
| */
| |
| function plugin_numbase(){
| |
| if($("[data-name='numbase']").length >= 1){
| |
|
| |
| var title = mw.config.get('wgPageName');
| |
| if (title.slice( -1 ) == "4") {
| |
| var no = 4
| |
| }
| |
| else {
| |
| var no = 3
| |
| }
| |
|
| |
| var trial = 0;
| |
| var d = new Date();
| |
| $("#sBtn").click(function(){
| |
| $("#description").css("display", "none");
| |
| $("#sBtn").css("display", "none");
| |
| $("#res").css("display", "table");
| |
| cpuNum = initNumbase();
| |
| document.getElementById('count').innerHTML = "시도 횟수: " + trial;
| |
| var bDate = d.getTime();
| |
| numGuess(bDate);
| |
| });
| |
|
| |
| function initNumbase() {
| |
| var choice = "";
| |
| var initArray = [0,1,2,3,4,5,6,7,8,9];
| |
| var i, j;
| |
| for (i = 0; i < no; i++) {
| |
| j = Math.floor(Math.random() * initArray.length);
| |
| choice += initArray[j];
| |
| initArray.splice(j,1);
| |
| }
| |
| return choice;
| |
| }
| |
|
| |
| function numGuess(bDate) {
| |
| document.getElementById('disp').style.display = 'table';
| |
| document.getElementById('numList').style.display = 'block';
| |
| var numb = document.getElementById('numList');
| |
| var numBlocks = "";
| |
| var disp = "";
| |
| document.getElementById('disp').innerHTML = disp;
| |
| for (i = 0; i < 10; i++) {
| |
| numBlocks += "" + i + "";
| |
| }
| |
| numBlocks += "C";
| |
| numBlocks += "입력";
| |
| numb.innerHTML = numBlocks;
| |
|
| |
| function restrictLen(l,n) {
| |
| if (l.length < no) {
| |
| l += n;
| |
| } else {
| |
| alert(no + " 자리로 입력하세요.");
| |
| }
| |
| return l;
| |
| }
| |
|
| |
| $("#numBlock0").click(function(){
| |
| disp = restrictLen(disp,0);
| |
| document.getElementById('disp').innerHTML = disp;
| |
| $("#numBlock0").css("display", "none");
| |
| });
| |
| $("#numBlock1").click(function(){
| |
| disp = restrictLen(disp,1);
| |
| document.getElementById('disp').innerHTML = disp;
| |
| $("#numBlock1").css("display", "none");
| |
| });
| |
| $("#numBlock2").click(function(){
| |
| disp = restrictLen(disp,2);
| |
| document.getElementById('disp').innerHTML = disp;
| |
| $("#numBlock2").css("display", "none");
| |
| });
| |
| $("#numBlock3").click(function(){
| |
| disp = restrictLen(disp,3);
| |
| document.getElementById('disp').innerHTML = disp;
| |
| $("#numBlock3").css("display", "none");
| |
| });
| |
| $("#numBlock4").click(function(){
| |
| disp = restrictLen(disp,4);
| |
| document.getElementById('disp').innerHTML = disp;
| |
| $("#numBlock4").css("display", "none");
| |
| });
| |
| $("#numBlock5").click(function(){
| |
| disp = restrictLen(disp,5);
| |
| document.getElementById('disp').innerHTML = disp;
| |
| $("#numBlock5").css("display", "none");
| |
| });
| |
| $("#numBlock6").click(function(){
| |
| disp = restrictLen(disp,6);
| |
| document.getElementById('disp').innerHTML = disp;
| |
| $("#numBlock6").css("display", "none");
| |
| });
| |
| $("#numBlock7").click(function(){
| |
| disp = restrictLen(disp,7);
| |
| document.getElementById('disp').innerHTML = disp;
| |
| $("#numBlock7").css("display", "none");
| |
| });
| |
| $("#numBlock8").click(function(){
| |
| disp = restrictLen(disp,8);
| |
| document.getElementById('disp').innerHTML = disp;
| |
| $("#numBlock8").css("display", "none");
| |
| });
| |
| $("#numBlock9").click(function(){
| |
| disp = restrictLen(disp,9);
| |
| document.getElementById('disp').innerHTML = disp;
| |
| $("#numBlock9").css("display", "none");
| |
| });
| |
| $("#numBlockC").click(function(){
| |
| disp = "";
| |
| document.getElementById('disp').innerHTML = disp;
| |
| $(".numBlock").css("display", "inline-flex");
| |
| });
| |
| $("#numBlockX").click(function(){
| |
| if (disp.length < no) {
| |
| alert(no + " 자리로 입력하세요.")
| |
| } else {
| |
| trial += 1
| |
| document.getElementById('count').innerHTML = "시도 횟수: " + trial;
| |
| v = valid(disp,cpuNum);
| |
| $("#res").append("" + trial + "" + disp + "" + v + "");
| |
| disp = "";
| |
| document.getElementById('disp').innerHTML = disp;
| |
| $(".numBlock").css("display", "inline-flex");
| |
| if ((v == "0B 3S" && no == 3) || (v == "0B 4S" && no == 4)) {
| |
| var dd = new Date();
| |
| var duration = Math.floor((dd.getTime() - bDate) / 1000);
| |
| document.getElementById('end').innerHTML = "축하합니다. 정수를 맞히셨습니다. " + trial + "회, " + duration + "초가 소비되었습니다. 이용해주셔서 감사합니다.";
| |
| $("#disp").css("display", "none");
| |
| $("#numList").css("display", "none");
| |
| $("#end").css("display", "inline");
| |
| return 0;
| |
| }
| |
| }
| |
| });
| |
| }
| |
|
| |
| function valid(u,c) {
| |
| var b = 0;
| |
| var s = 0;
| |
| var bs;
| |
| for (i = 0; i < no; i++) {
| |
| for (j = 0; j < no; j++) {
| |
| if (u[i] == c[j]) {
| |
| if (i == j) {
| |
| s += 1;
| |
| }
| |
| else {
| |
| b += 1;
| |
| }
| |
| }
| |
| }
| |
| }
| |
| bs = "" + b + "B " + s + "S"
| |
| return bs;
| |
| }
| |
|
| |
|
| |
| }
| |
|
| |
| }
| |
| $( plugin_numbase );
| |
| /* numbase 끝 */
| |
|
| |
| /** 플러그인 uncyslide***************************
| |
| * 백괴슬라이드 실행
| |
| * 버전 => 1.1.02
| |
| * 작성자 : [[사용자:BANIP|BANIP]]
| |
| * JSON => uncyslide = {"name":"uncyslide","descript":"백괴슬라이드 실행","version":"1.1.02","local":true,"creat":"BANIP","state":"백괴슬라이드/플러그인","executable":true};
| |
| */
| |
| function plugin_uncyslide(){
| |
| if($("[data-name='uncyslide']").length >= 1){
| |
| // 이부부분에 코드 입력 //
| |
| var slideable = plugin_Slideable();
| |
| var create = slideable.create;
| |
| var execute = slideable.execute;
| |
| var dispose = slideable.dispose;
| |
|
| |
| var rankingSystem = plugin_RankingSystem()("백괴슬라이드/랭킹", function(prev,next){ return Number(prev.time) - Number(next.time)});
| |
| var outputKeys = {time:"소요시간"};
| |
| var startMap = localStorage.getItem("uncySlide/startmap") || 0;
| |
| var game = {
| |
| 0: {
| |
| center: "아래로 밀어주세요.",
| |
| bottom: 1
| |
| },
| |
| 1: {
| |
| center: "오른쪽으로 밀어보세요.",
| |
| right: 2
| |
| },
| |
| 2: {
| |
| center: "어디로 밀어보실래요?",
| |
| top: 3,
| |
| bottom: 3,
| |
| },
| |
| 3: {
| |
| center: "반갑습니다. 백괴슬라이드입니다.",
| |
| bottom: 4,
| |
| },
| |
| 4: {
| |
| center: "어디로 당기고 미느냐에 따라, 게임의 결과가 달라집니다.",
| |
| bottom: 5,
| |
| },
| |
| 5: {
| |
| center: "는 개뿔 이겜 시스템만든다고 그런 장황한거 만들 정신머리는 없었습니다",
| |
| bottom: 5.1,
| |
| },
| |
| 5.1: {
| |
| center: "진심 힘들었습니다.",
| |
| bottom: 5.2,
| |
| },
| |
| 5.2: {
| |
| center: "잘했죠?",
| |
| bottom: 5.3,
| |
| },
| |
| 5.3: {
| |
| center: "위로 밀어서 칭찬하거나 아래로 밀어서 욕해주세요.",
| |
| top: 5.4,
| |
| bottom: 5.5,
| |
| },
| |
| 5.4: {
| |
| center: "감사합니다. 헤헤",
| |
| bottom: 6,
| |
| },
| |
| 5.5: {
| |
| center: "흑흑.. 힘들었는데..",
| |
| bottom: 6,
| |
| },
| |
| 6: {
| |
| center: "그래도 미디어위키의 틀에서 벗어난 겜인만큼 최대한 나은 경험을 선사하고자 노력했습니다. 잘부탁드립니다.",
| |
| bottom: function(){
| |
| localStorage.setItem("uncySlide/startmap","main");
| |
| execute("main");
| |
| },
| |
| },
| |
| main: {
| |
| center: "아래: 게임시작토론: 위설명: 오른쪽",
| |
| bottom: function(){ execute("start",{count:100,time:Date.now()}) },
| |
| top: "debate",
| |
| right: "i0",
| |
| },
| |
| i0: {
| |
| center:"가장자리에 화살표 보이죠?",
| |
| bottom:"i1"
| |
| },
| |
| i1: {
| |
| center:"화면을 넘겨서 드래그해서 진행하는 게임이에요.",
| |
| bottom:"i2"
| |
| },
| |
| i2: {
| |
| center:"원래라면 좀 큰 스케일의 게임으로 만들고 싶었는데..",
| |
| bottom:"i3"
| |
| },
| |
| i3: {
| |
| center:"제 역량이 겜 크기에서 다 드러나네요...",
| |
| bottom:"i4"
| |
| },
| |
| i4: {
| |
| center:"아무쪼록 힘들게 만들었으니 재밌게 즐겨주세요.",
| |
| right:"main"
| |
| },
| |
| debate: function(){
| |
| location.href = "https://libertyga.me/wiki/%ED%86%A0%EB%A1%A0:%EB%B0%B1%EA%B4%B4%EC%8A%AC%EB%9D%BC%EC%9D%B4%EB%93%9C";
| |
| },
| |
| start: function(arg){
| |
| function getRandomDirection(){
| |
| switch( Math.ceil(Math.random() * 4) ){
| |
| case 1: return "top"; break;
| |
| case 2: return "bottom"; break;
| |
| case 3: return "left"; break;
| |
| case 4: return "right"; break;
| |
| }
| |
| }
| |
| function getColorCode(count,maxcount){
| |
| var code = "hsl(" + count / maxcount * 360 +",100%,70%)";
| |
| return code
| |
| }
| |
|
| |
| var count = arg.count;
| |
| var maxcount = arg.maxcount || count;
| |
| var time = arg.time;
| |
| var $this = $(this);
| |
| var timerInterval;
| |
| var slideableItem = {
| |
| center: function(){
| |
| var $this = $(this);
| |
| $this.css({
| |
| "background": getColorCode(count,maxcount)
| |
| });
| |
|
| |
| timerInterval = setInterval(function(){
| |
| var overtime = (Date.now() - time) * 0.001;
| |
| var printableTime = overtime.toFixed(2);
| |
| $this.find(".counter").html(printableTime + "초");
| |
| },5)
| |
|
| |
| return "" + count + "";
| |
| }
| |
| };
| |
|
| |
| slideableItem[getRandomDirection()] = function(){
| |
| clearInterval(timerInterval);
| |
| if(count === 1) return execute("result",{count:count - 1,time:time,maxcount:maxcount});
| |
| execute("start",{count:count - 1,time:time,maxcount:maxcount})
| |
| };
| |
|
| |
| create(slideableItem);
| |
| },
| |
| result: function(arg){
| |
| var maxcount = arg.maxcount || count;
| |
| var time = ( (Date.now() - arg.time) / 1000 ).toFixed(2);
| |
| var updateParam = {
| |
| time: time,
| |
| name: mw.config.get("wgUserName")
| |
| };
| |
| rankingSystem.update(updateParam,function(rankingScore,thisScore){ return rankingScore.time > thisScore.time},outputKeys);
| |
|
| |
| create({
| |
| center: "갯수: " + maxcount + " 시간: " + time + "왼쪽: 메인으로오른쪽: 토론으로",
| |
| left:"main",
| |
| right:"debate",
| |
| });
| |
| }
| |
| }
| |
| dispose(game, startMap, {});
| |
|
| |
| }
| |
|
| |
| }
| |
| $( plugin_uncyslide );
| |
| /* uncyslide 끝 */
| |
|
| |
| /** 플러그인 Slideable***************************
| |
| * 슬라이드 플러그인 라이브러리
| |
| * 버전 => 1.0.21
| |
| * 작성자 : [[사용자:BANIP|BANIP]]
| |
| * JSON => Slideable = {"name":"Slideable","descript":"슬라이드 플러그인 라이브러리","version":"1.0.21","local":true,"creat":"BANIP","state":"사용자:BANIP/플러그인/슬라이드","executable":false};
| |
| */
| |
| function plugin_Slideable(){
| |
| if($("[data-name='Slideable']").length >= 1){
| |
| // 이부부분에 코드 입력 //
| |
| //모든 키 순회
| |
| function forEach(object, callback) {
| |
| for (var key in object) {
| |
| var variable = object[key];
| |
| callback(variable, key);
| |
| }
| |
| }
| |
|
| |
| function create(directionData) {
| |
| function initClassName($target, data) {
| |
| forEach(data, function(value, direction) {
| |
| $target.find("." + direction).addClass("on");
| |
| })
| |
| }
| |
|
| |
| function initDOM($target, data) {
| |
| $target[0].data = data;
| |
| $target.find(".center").html(data.center);
| |
| $target.find(".top.on").css("background","url('https://upload.wikimedia.org/wikipedia/commons/8/85/Arrow_top_svg.svg') no-repeat center");
| |
| $target.find(".bottom.on").css("background","url('https://upload.wikimedia.org/wikipedia/commons/f/f2/Arrow_bottom_svg.svg') no-repeat center");
| |
| $target.find(".left.on").css("background","url('https://upload.wikimedia.org/wikipedia/commons/4/40/Arrowleft_svg.svg') no-repeat center");
| |
| $target.find(".right.on").css("background","url('https://upload.wikimedia.org/wikipedia/commons/e/ec/Arrow2right.svg') no-repeat center");
| |
| }
| |
|
| |
| var slideUtil = {
| |
| moveObject: function($this, axis) {
| |
| var x = axis[0], y = axis[1];
| |
|
| |
| var data = $this[0].data;
| |
| if (!data.right && x > 0) x = 0;
| |
| if (!data.left && x < 0) x = 0;
| |
| if (!data.top && y < 0) y = 0;
| |
| if (!data.bottom && y > 0) y = 0;
| |
| $this.css("transform", "translate(" + x + "px," + y + "px)");
| |
| },
| |
| isHideable: function($this, axis, limit) {
| |
| var x = axis[0], y = axis[1];
| |
| var data = $this[0].data;
| |
| if (data.right && x > limit) return "right";
| |
| if (data.left && x < limit * -1) return "left";
| |
| if (data.bottom && y > limit) return "bottom";
| |
| if (data.top && y < limit * -1) return "top";
| |
| },
| |
| hide: function(direction, $this) {
| |
| function getCss(direction) {
| |
| var css = {
| |
| opacity: 0.01
| |
| };
| |
| var interval = 50;
| |
| switch (direction) {
| |
| case "left":
| |
| css.left = -1 * interval + "vw";
| |
| break;
| |
| case "right":
| |
| css.left = interval + "vw";
| |
| break;
| |
| case "bottom":
| |
| css.top = interval + "vh";
| |
| break;
| |
| case "top":
| |
| css.top = -1 * interval + "vh";
| |
| break;
| |
| }
| |
|
| |
| return css;
| |
| }
| |
|
| |
| var self = $this[0];
| |
| var data = self.data;
| |
| if (self.isHide === true) {
| |
| return;
| |
| }
| |
| self.isHide = true;
| |
| $this.animate(getCss(direction), {
| |
| duration: 300,
| |
| easing: "swing",
| |
| start: data[direction],
| |
| complete: function() {
| |
| $this.remove();
| |
| }
| |
| });
| |
| }
| |
| }
| |
|
| |
| function setEvent($target, data) {
| |
| var util = slideUtil;
| |
| var moveLimit = 50;
| |
|
| |
| $(".slideable").mousedown(function(e) {
| |
| this.isMouseDown = true;
| |
| this.startAxis = [e.clientX, e.clientY];
| |
| })
| |
|
| |
| $(".slideable").mousemove(function(e) {
| |
| if (this.isMouseDown) {
| |
| event.preventDefault()
| |
| var axis = [e.clientX, e.clientY];
| |
| var startAxis = this.startAxis;
| |
| var moveInterval = [axis[0] - startAxis[0], axis[1] - startAxis[1]]
| |
| util.moveObject($(this), moveInterval);
| |
| var hideDirection = util.isHideable($(this), moveInterval, moveLimit);
| |
| if (hideDirection) util.hide(hideDirection, $(this));
| |
| }
| |
| })
| |
|
| |
| $(".slideable").mouseup(function(e) {
| |
| this.isMouseDown = false;
| |
| })
| |
|
| |
| function getTouchEvent(e) {
| |
| return e.originalEvent.touches[0]
| |
| }
| |
|
| |
| $(".slideable").on("touchstart", function(e) {
| |
| var touch = getTouchEvent(e);
| |
|
| |
| this.isMouseDown = true;
| |
| this.startAxis = [touch.clientX, touch.clientY];
| |
| })
| |
|
| |
| $(".slideable").on("touchmove", function(e) {
| |
| event.preventDefault()
| |
| if (this.isMouseDown) {
| |
| event.preventDefault()
| |
| var touch = getTouchEvent(e);
| |
| var axis = [touch.clientX, touch.clientY];
| |
| var startAxis = this.startAxis;
| |
| var moveInterval = [axis[0] - startAxis[0], axis[1] - startAxis[1]]
| |
| util.moveObject($(this), moveInterval);
| |
| var hideDirection = util.isHideable($(this), moveInterval, moveLimit);
| |
| if (hideDirection) util.hide(hideDirection, $(this));
| |
| }
| |
| })
| |
|
| |
| $(".slideable").on("touchend", function(e) {
| |
| this.isMouseDown = false;
| |
| })
| |
|
| |
| }
| |
|
| |
| //슬라이드아이템의 방향키로 숫자 혹은 문자로 지정된 경우
| |
| //함수로 변환
| |
| function setExecutable(target, item){
| |
| forEach(item,function(value,direction){
| |
| new Promise(function(resolve, reject){
| |
| if(direction === "center"){
| |
| switch( typeof value ){
| |
| case "function":
| |
| resolve( value.bind(target)() );
| |
| break;
| |
| }
| |
| } else {
| |
| switch( typeof value ){
| |
| case "string": case "number":
| |
| resolve(function(){ execute(value); }.bind(target));
| |
| break;
| |
| }
| |
| }
| |
| }).then(function(result){
| |
| item[direction] = result;
| |
| })
| |
|
| |
| })
| |
| }
| |
|
| |
| var $target = $(".slideable.cloneable").clone().removeClass("cloneable");
| |
| $("body").prepend($target);
| |
| setExecutable($target[0], directionData);
| |
| initClassName($target, directionData);
| |
| initDOM($target, directionData);
| |
| setEvent($target, directionData);
| |
| }
| |
|
| |
| // create는 다른 함수들에 의존하지 않음 //
| |
| var game;
| |
|
| |
| function execute(number, argument) {
| |
| dispose(game, number, argument);
| |
| }
| |
|
| |
| function dispose(slideableArray, start, argument) {
| |
| game = slideableArray;
| |
|
| |
| var slideableItem = slideableArray[start];
| |
| switch (typeof slideableItem) {
| |
| case "function":
| |
| slideableItem(argument);
| |
| break;
| |
| case "object":
| |
| create(slideableItem);
| |
| break;
| |
| }
| |
| }
| |
|
| |
| //모바일 전체화면으로 수정
| |
| var setFullScreen = (function(){
| |
| //window.scrollTo(0,1);
| |
| })();
| |
|
| |
| return {
| |
| create: create,
| |
| execute: execute,
| |
| dispose: dispose
| |
| }
| |
|
| |
| }
| |
|
| |
| }
| |
| /* Slideable 끝 */
| |
|
| |
|
| |
|
| |
| /** 플러그인 RankingSystem***************************
| |
| * 랭킹시스템 라이브러리
| |
| * 버전 => 1.1.0
| |
| * 작성자 : [[사용자:BANIP|BANIP]]
| |
| * JSON => RankingSystem = {"name":"RankingSystem","descript":"랭킹시스템 라이브러리","version":"1.1.0","local":true,"creat":"BANIP","state":"사용자:BANIP/플러그인/랭킹시스템","executable":false};
| |
| */
| |
| function plugin_RankingSystem(){
| |
| if($("[data-name='RankingSystem']").length >= 1){
| |
| // 이부부분에 코드 입력 //
| |
|
| |
| /**
| |
| * @param
| |
| {string} documentTitle 랭킹정보가 있는 문서의 제목.
| |
| {function} sortCallback 랭킹을 정렬할때 기준으로 사용하는 함수
| |
| {any} prev 랭킹 정렬 기준으로 사용할 왼쪽의 값
| |
| {any} next 랭킹 정렬 기준으로 사용할 오른쪽의 값
| |
| {object} api MediaWikiapi의 인스턴스, 없어도 됨.
| |
|
| |
| @return {Object}
| |
| {function} get 랭킹정보를 object형태로 획득
| |
| {function} update 랭킹정보 업데이트
| |
| {object} updateInfo 업데이트할 사용자 정보
| |
| {function} updateCriteria 사용자정보의 업데이트 기준
| |
| @param {any} rankingScore 랭킹에서 사용중인 스코어
| |
| {any} thisScore 사용자 스코어
| |
| @return{bool} true가 반환되면 업데이트
| |
| {object} alternateKeys 랭킹에서 보여지는 대체 키
| |
| */
| |
|
| |
| return function(documentTitle, sortCallback, api) {
| |
| function forEach(object, callback) {
| |
| for (var key in object) {
| |
| var variable = object[key];
| |
| callback(variable, key);
| |
| }
| |
| }
| |
|
| |
| function getRankingJSON(rankingDoc) {
| |
| if (!rankingDoc) return {};
| |
| var includeOnlyString = "includeonly"
| |
| var regexp = new RegExp("\<" + includeOnlyString + "\>(.*)\<\/" + includeOnlyString + "\>");
| |
| var stringRanking = regexp.exec(rankingDoc)[1];
| |
| return JSON.parse(stringRanking);
| |
| }
| |
|
| |
| function updateDoc(rankingJSON, api, alternateKeys) {
| |
| //alternateKeys가 반영된 개개인의 랭킹정보 획득
| |
| function getOutputJSON(json) {
| |
| var result = {};
| |
| forEach(json, function(value, key) {
| |
| key = alternateKeys[key] || key;
| |
| result[key] = value;
| |
| })
| |
| return result;
| |
| }
| |
|
| |
| //보여지는 형태의 랭킹정보 획득
| |
| function getOutputString(json) {
| |
| var name = json.name;
| |
| var result = "* '''" + name + "''' : ";
| |
| forEach(json, function(value, key) {
| |
| if (key === "name") return;
| |
| key = alternateKeys[key] || key;
| |
| result += key + ": " + value + ", ";
| |
| })
| |
| result += "\n"
| |
| return result
| |
| }
| |
|
| |
| var stringRanking = JSON.stringify(rankingJSON);
| |
| var result = "<includ" + "eonly>" + stringRanking + "</inclu" + "deonly>\n";
| |
| result += "<onlyin" + "clude>\n";
| |
|
| |
| var rankingList = Object.entries(rankingJSON).sort(function(prev,next){
| |
| return sortCallback(prev[1],next[1])
| |
| }).map(function(value){
| |
| return value[0]
| |
| });
| |
|
| |
| rankingList.forEach(function(key) {
| |
| var json = rankingJSON[key];
| |
| var outputJSON = getOutputJSON(json);
| |
| result += getOutputString(outputJSON)
| |
| });
| |
|
| |
| result += "</only" + "include>";
| |
| var reply = documentTitle.replace(new RegExp("\/.*"),"") + " 점수 갱신";
| |
| api.changeDocument(documentTitle, reply, result, true);
| |
| return result;
| |
| }
| |
|
| |
| function updateUserScore(rankingJSON, thisScore, updateCriteria) {
| |
| updateCriteria = updateCriteria || function(rankingScore, thisScore) {
| |
| return rankingScore.score < thisScore.score;
| |
| }
| |
|
| |
| var userName = thisScore.name;
| |
| var rankingScore = rankingJSON[userName];
| |
|
| |
| if (!rankingScore || updateCriteria(rankingScore, thisScore)) {
| |
| rankingJSON[userName] = thisScore;
| |
| }
| |
| }
| |
|
| |
| api = api || MediaWikiAPI();
| |
| var userName = mw.config.get("wgUserName");
| |
| var rankingDoc = api.getDocument(documentTitle);
| |
| var rankingJSON = getRankingJSON(rankingDoc);
| |
|
| |
| var actions = {
| |
| get: function() {
| |
| return rankingJSON;
| |
| },
| |
| update: function(updateInfo, updateCriteria, alternateKeys) {
| |
| rankingJSON = actions.get();
| |
| updateUserScore(rankingJSON, updateInfo, updateCriteria);
| |
| updateDoc(rankingJSON, api, alternateKeys);
| |
| }
| |
| }
| |
| return actions;
| |
| }
| |
|
| |
|
| |
| }
| |
|
| |
| }
| |
| /* RankingSystem 끝 */
| |