Войти на сайт

Авторизация, ждите ...
×
Правила раздела:
1 Задавайте конкретные вопросы. Для болтовни есть свободный раздел.
2 По возможности давайте конкретные ответы.
3 Один вопрос=одна тема. Если хотите задать ещё вопрос, то начинайте новую тему.
4 Название темы должно составлять сам вопрос, и быть максимально конкретным. Рекомендуется начинать тему словами "Как", "Что", "Почему". А первый пост повторяет вопрос и даёт расширенные сведения.
5 Рекомендуется указывать версию мейкера (2000, 2003, RMXP, RMVX, ACE, IGM, и.т.д.. Это важно, и всё равно ведь спросят.
6 Темы "Пара вопросов", "Помогите", и подобные им - самый лёгкий путь к бану.
7 Поиск находится вверху справа.
А. Названия подразделов этого раздела уточняются. Советы принимаются.

ТЕМА: CSS дизайн для RS_InputDialog

CSS дизайн для RS_InputDialog 1 год 10 мес. назад #127154

  • Alexandr_7
  • Alexandr_7 аватар
  • Вне сайта
  • Архитектор Миров
  • Сообщений: 1185
  • Спасибо получено: 539
  • УчительВетеранПроект месяца 3 местоПроект года 3 местоПроект месяца 2 местоПроект месяца 1 место
Здравствуйте. Может кто-нибудь мне сделать дизайн (подходящий к моему проекту "Дом Маленькой Ведьмы") для плагина RS_InputDialog/
Дело в том что стиль пишется в плагине на CSS, а я не умею и ненавижу работать с этими файлами.
Вот код плагина:
/*:
 * RS_InputDialog.js
 * @plugindesc This plugin allows you to display Text Edit Box on the screen. <RS_InputDialog>
 * @author biud436
 * @target MV MZ
 *
 * @command InputDialogOpen
 * @text Input Dialog Open
 * @desc Opens Input Dialog.
 * 
 * @command InputDialogWidth
 * @text Input Dialog Width
 * @desc Changes the width of Input Dialog.
 * 
 * @arg width
 * @text Width
 * @desc Width
 * @type number
 * @default 488
 * 
 * @command InputDialogText
 * @text Input Dialog Text
 * @desc Changes the text of Input Dialog for representing the description.
 * 
 * @arg text
 * @text Text
 * @desc Sets the string that is the top of the text box.
 * @default Please enter the value...
 * 
 * @command InputDialogVariableID
 * @text Input Dialog Variable ID
 * @desc Changes an id of the variable for saving the value.
 * 
 * @arg variableID
 * @text Variable ID
 * @desc Sets an id of the game variables.
 * @type variable
 * @default 3
 * 
 * @command InputDialogDebug
 * @text Input Dialog Debug
 * @desc Displays a alert window of the browser when you are pressing the enter
 * 
 * @arg isDebug
 * @text Debug
 * @desc Whether this determines the alert window.
 * @type boolean
 * @on YES
 * @off NO
 * @default false
 * 
 * @command InputDialogMaxLength
 * @text Input Dialog Max Length
 * @desc Specifies the maximum number of character for an input field
 * 
 * @arg maxLength
 * @text Max Length
 * @desc Specifies the maximum number of character for an input field
 * @type number
 * @min 1
 * @max 255
 * @default 255
 * 
 * command InputDialogPos
 * @text Input Dialog Position
 * @desc This plugin commands decide how to set the position of the input dialog.
 * 
 * @arg pos
 * @text Position
 * @desc Specify the position of the input dialog.
 * @type select
 * @option center
 * @option pos
 * @default center
 * 
 * @arg posX
 * @text Position X
 * @desc Position X (If 'pos' is selected!)
 * @type number
 * @default 0
 * 
 * @arg posY
 * @text Position Y
 * @desc Position Y (If 'pos' is selected!)
 * @type number
 * @default 0
 * 
 * @command InputDialogButtonOK
 * @text Input Dialog Button OK
 * @desc Input Dialog Button OK
 * 
 * @arg text
 * @text Text
 * @desc Text
 * @default Ok
 * 
 * @command InputDialogButtonCancel
 * @text Input Dialog Button Cancel
 * @desc Input Dialog Button Cancel
 * 
 * @arg text
 * @text Text
 * @desc Text
 * @default Cancel
 
 
 
 * @param textBox Width
 * @type number
 * @desc Sets the width of Text Box.
 * @default 488
 * @decimals 0
 * @min 28
 *
 * @param textBox Height
 * @type number
 * @desc Sets the height of Text Box.
 * @default 36
 * @decimals 0
 * @min 8
 *
 * @param variable ID
 * @type variable
 * @desc Sets an id of the game variables.
 * @default 3
 *
 * @param debug
 * @type boolean
 * @desc Whether this determines the alert window.
 * @default false
 *
 * @param Text Hint
 * @desc Sets the string that is the top of the text box.
 * @default Please enter the value...
 *
 * @param direction
 * @type select
 * @desc Sets the direction of content flow.
 * @default ltr
 * @option Left to Right
 * @value ltr
 * @option Right to Left
 * @value rtl
 *
 * @param Max Length
 * @type number
 * @desc Specifies the maximum number of character for an input field
 * @default 255
 * @min 1
 * @max 255
 *
 * @param Style
 *
 * @param CSS
 * @parent Style
 * @type note
 * @desc Edit the css as you want.
 * @default ""
 *
 * @param Button Name
 *
 * @param Ok
 * @parent Button Name
 * @text Ok Button Name
 * @desc Specify the name of the Ok Button.
 * @default OK
 *
 * @param Cancel
 * @parent Button Name
 * @text Cancel Button Name
 * @desc Specify the name of the Cancel Button.
 * @default Cancel
 *
 * @param Position
 * @text Initial Position
 * @desc Specify the position of the input dialog.
 * ('center' or '0, 0')
 * @default center
 *
 * @help
 * =============================================================================
 * Plugin Commands
 * =============================================================================
 * - Opens Input Dialog.
 * InputDialog open
 *
 * - Changes the width of Input Dialog.
 * InputDialog width 488
 *
 * - Changes the text of Input Dialog for representing the description.
 * InputDialog text Please enter the string...
 *
 * - Changes an id of the variable for saving the value.
 * InputDialog variableID 3
 *
 * - Displays a alert window of the browser when you are pressing the enter
 * InputDialog debug true
 *
 * - Specifies the maximum number of character for an input field
 * InputDialog maxLength 10
 *
 * - This plugin commands decide how to set the position of the input dialog.
 * InputDialog pos center
 * InputDialog pos 0 0
 *
 * =============================================================================
 * Change Log
 * =============================================================================
 * 2016.08.09 (v1.0.0) - First Release.
 * 2016.08.09 (v1.0.1) - Added Background Color.
 * 2016.08.10 (v1.0.1a) - Added ID Variables.
 * 2016.08.10 (v1.1.0) - Fixed Window_DialogHelp class into the plugin.
 * 2016.08.16 (v1.1.1) - Added the direction property setting the direction of content flow.
 * 2016.08.16 (v1.1.1a) - Fixed a whitespace bug.
 * 2016.10.14 (v1.1.2) - Fixed the issue that is not working in Battle.
 * 2016.10.14 (v1.1.3) :
 * - Fixed the bug that does not change the background color.
 * - Fixed the bug that does not change the variable ID.
 * 2016.10.17 (v1.1.4) - Fixed the frame works of input dialog in battle.
 * 2016.10.18 (v1.1.5) - Fixed an issue that battler's movement is too fast.
 * 2016.10.29 (v1.1.6) - Added the function that allows you to specify the maximum number of character for an input field.
 * 2016.11.13 (v1.1.6a) - Fixed the issue that is directly calling the requestUpdate function of SceneManager.
 * 2016.12.02 (v1.1.6e) :
 * - Added some style codes such as a text shadow and an outline into the text box.
 * - Fixed the way that can temporarily stop attack and skill actions with an enemy when the text box is activated in the battle.
 * - It will not process the text input when the text box is not shown in the battle.
 * - In the debug mode, It adds the result value to a log window after the text input is done.
 * 2016.12.08 (v1.1.6h) - Removed the text hint window.
 * 2016.12.17 (v1.1.6i) - Fixed an issue that an integer value could not be checked due to the text type issue.
 * 2017.01.30 (v1.1.7) - Fixed an issue that is not working properly if the text dialog has a string to start with a number.
 * 2017.02.16 (v1.1.8) :
 * - Fixed incorrect position and width, height values in the text box.
 * - Added new feature that indicates the input dialog at the top position of the screen when pressing any key on your own mobile device.
 * - Added new feature that automatically returns a result of the text box if you did not press anything.
 * 2018.01.25 (v1.1.8a) - test...
 * 2018.01.30 (v1.1.9) :
 * - Added the button called 'OK'.
 * - Added the button called 'Cancel'.
 * - Removed the feature that can change the background-color of the input dialog.
 * - Fixed the issue that is not clicking the button in the mobile.
 * 2018.02.03 (v1.1.10) :
 * - Fixed the issue that is not working in RMMV 1.5.1
 * - Fixed the default value of the plugin parameter  called 'CSS'.
 * 2018.02.06 (v1.1.11) :
 * - Fixed the issue that is not working in the battle scene.
 * 2018.10.22 (v1.1.15) :
 * - Added a plugin command that sets the position of the input dialog.
 * - Added a feature that the keyboard layout is displayed again if you touch the text box from android devices.
 * - On the mobile device, the font size is now set to 1rem (16px).
 * - Fixed the default UI-theme is to black.
 * - In the chromium 69+ more over, The input element is always displayed even though <canvas>'s z-index is large than <input> element's z-index. so I've fixed that.
 * 2019.03.05 (v1.1.16) :
 * - Fixed the issue that can not create a background when using Irina_PerformanceUpgrade.
 */
/*:ko
 * @plugindesc 화면에 텍스트 에디터 띄워 텍스트 값을 변수로 받습니다 <RS_InputDialog>
 * @author 러닝은빛(biud436)
 * @target MV MZ
 * 
 * @command InputDialogOpen
 * @text Input Dialog Open
 * @desc Opens Input Dialog.
 * 
 * @command InputDialogWidth
 * @text Input Dialog Width
 * @desc Changes the width of Input Dialog.
 * 
 * @arg width
 * @text Width
 * @desc Width
 * @type number
 * @default 488
 * 
 * @command InputDialogText
 * @text Input Dialog Text
 * @desc Changes the text of Input Dialog for representing the description.
 * 
 * @arg text
 * @text Text
 * @desc Sets the string that is the top of the text box.
 * @default Please enter the value...
 * 
 * @command InputDialogVariableID
 * @text Input Dialog Variable ID
 * @desc Changes an id of the variable for saving the value.
 * 
 * @arg variableID
 * @text Variable ID
 * @desc Sets an id of the game variables.
 * @type variable
 * @default 3
 * 
 * @command InputDialogDebug
 * @text Input Dialog Debug
 * @desc Displays a alert window of the browser when you are pressing the enter
 * 
 * @arg isDebug
 * @text Debug
 * @desc Whether this determines the alert window.
 * @type boolean
 * @on YES
 * @off NO
 * @default false
 * 
 * @command InputDialogMaxLength
 * @text Input Dialog Max Length
 * @desc Specifies the maximum number of character for an input field
 * 
 * @arg maxLength
 * @text Max Length
 * @desc Specifies the maximum number of character for an input field
 * @type number
 * @min 1
 * @max 255
 * @default 255
 * 
 * command InputDialogPos
 * @text Input Dialog Position
 * @desc This plugin commands decide how to set the position of the input dialog.
 * 
 * @arg pos
 * @text Position
 * @desc Specify the position of the input dialog.
 * @type select
 * @option center
 * @option pos
 * @default center
 * 
 * @arg posX
 * @text Position X
 * @desc Position X (If 'pos' is selected!)
 * @type number
 * @default 0
 * 
 * @arg posY
 * @text Position Y
 * @desc Position Y (If 'pos' is selected!)
 * @type number
 * @default 0
 * 
 * @command InputDialogButtonOK
 * @text Input Dialog Button OK
 * @desc Input Dialog Button OK
 * 
 * @arg text
 * @text Text
 * @desc Text
 * @default Ok
 * 
 * @command InputDialogButtonCancel
 * @text Input Dialog Button Cancel
 * @desc Input Dialog Button Cancel
 * 
 * @arg text
 * @text Text
 * @desc Text
 * @default Cancel
 
 
 
 * @param textBox Width
 * @text 텍스트박스 가로 크기
 * @type number
 * @desc 텍스트 박스의 가로 크기를 지정하세요.
 * @default 488
 * @decimals 0
 * @min 28
 *
 * @param textBox Height
 * @text 텍스트박스 세로 크기
 * @type number
 * @desc 텍스트 박스의 세로 크기를 지정하세요.
 * @default 36
 * @decimals 0
 * @min 8
 *
 * @param variable ID
 * @text 변수 ID
 * @type variable
 * @desc 텍스트 입력 결과값을 전달 받을 변수의 ID 값을 지정하세요.
 * @default 3
 *
 * @param debug
 * @text 디버그 여부
 * @type boolean
 * @desc 디버그 용도로 alert 창을 표시할 지 여부를 설정하세요.
 * @default false
 *
 * @param Text Hint
 * @text 텍스트 힌트
 * @desc 텍스트 박스 내부에 가이드 글자를 남깁니다.
 * @default Please enter the value...
 *
 * @param direction
 * @text 텍스트 방향
 * @type select
 * @desc 텍스트의 방향을 선택하십시오.
 * @default ltr
 * @option 왼쪽에서 오른쪽으로 (기본)
 * @value ltr
 * @option 오른쪽에서 왼쪽으로
 * @value rtl
 *
 * @param Max Length
 * @text 텍스트 최대 길이
 * @type number
 * @desc 텍스트 입력 필드에서 최대로 입력할 수 있는 텍스트 길이 값을 지정하십시오.
 * @default 255
 * @min 1
 * @max 255
 *
 * @param Style
 * @text 스타일시트
 *
 * @param CSS
 * @parent Style
 * @type note
 * @desc 스타일시트를 수정할 수 있습니다 (잘 아시는 분만 사용하십시오)
 * @default ""
 *
 * @param Button Name
 * @text 버튼 명
 *
 * @param Ok
 * @text 확인 버튼
 * @parent Button Name
 * @desc 확인 버튼의 이름을 지정합니다.
 * @default 확인
 *
 * @param Cancel
 * @text 취소 버튼
 * @parent Button Name
 * @desc 취소 버튼의 이름을 지정합니다.
 * @default 취소
 *
 * @param Position
 * @text 초기 위치
 * @desc 초기 위치를 지정하세요.
 * ('center' 또는 '0, 0')
 * @default center
 *
 * @help
 * =============================================================================
 * 플러그인 명령에 대해...
 * =============================================================================
 * 텍스트 입력창을 열려면 다음 플러그인 명령을 호출해야 합니다. 이 명령은 맵이나 전투
 * 에서 호출이 가능합니다. 전투일 경우에는 동작이 약간 달라집니다.
 *
 * 전투 장면에서는 Yanfly님의 Battle Core Engine과 같이 사용하면 편리합니다.
 *
 * InputDialog open
 *
 * 텍스트 입력창의 가로 길이를 변경하는 명령어입니다.
 *
 * InputDialog width 488
 *
 * 텍스트 입력창의 가이드 텍스트를 바꿀 수 있는 명령입니다. 문장 형식으로 작성할 수
 * 있습니다. 내부에서 문장으로 조합됩니다.
 *
 * InputDialog text Please enter the string...
 *
 * 입력된 텍스트 값을 전달 받을 변수를 변경할 수 있습니다. 변수의 ID 값을 지정하세요.
 *
 * InputDialog variableID 3
 *
 * 텍스트 입력 이후에 결과 값을 alert 창에 표시하려면 사용하십시오.
 *
 * InputDialog debug true
 *
 * 텍스트 입력창에 입력할 수 있는 최대 텍스트 길이를 변경할 수 있습니다.
 *
 * InputDialog maxLength 10
 *
 * 텍스트 입력 상자의 위치를 바꾸려면 pos 명령을 사용해야 합니다.
 * 첫번째 인자에 "center"라는 문자열을 넘기면 화면 중앙에 텍스트 입력 상자가 정렬됩니다.
 * 모바일에서는 중앙 정렬을 되도록이면 사용하지 않는 것이 좋습니다.
 * 키보드 레이아웃에 의해 텍스트 입력 상자가 가려질 가능성이 있습니다.
 *
 * 문자열이 아닌 좌표 x, y 값을 지정하면 해당 화면 좌표에 텍스트 입력 상자를 설정하게 됩니다.
 *
 * InputDialog pos center
 * InputDialog pos 0 0
 *
 * =============================================================================
 * UI 수정에 대해
 * =============================================================================
 * CSS 매개변수에서 CSS를 이용하여 UI를 수정할 수 있습니다.
 * 주로 색상 값과 폰트 크기를 조절할 수 있으며, 모바일 장치에서만 바뀌게 할 수도 있습니다.
 *
 * 또한 텍스트 입력 상자는 화면 중앙에만 고정되는 것이 아닙니다. 플러그인 명령을 통해 손 쉽게 바꿀 수 있고,
 * UI도 CSS를 편집하면 바꿀 수 있습니다.
 * (플러그인 파일을 텍스트 에디터로 열어서 직접 편집하는 것이 더 좋습니다)
 *
 * 스크립트 명령어로 위치를 수정하려면, 먼저 아래 변수 값을 false로 설정해야 합니다.
 * RS.InputDialog.Params.isCenterAlignment = false;
 *
 * 그 후, 포인트 값을 수정하여 위치를 조절할 수 있습니다.
 *
 * RS.InputDialog.Params.pos.x = 0;
 * RS.InputDialog.Params.pos.y = 0;
 *
 * =============================================================================
 * 변동 사항
 * =============================================================================
 * 2016.08.09 (v1.0.0) - First Release.
 * 2016.08.09 (v1.0.1) - Added Background Color.
 * 2016.08.10 (v1.0.1a) - Added ID Variables.
 * 2016.08.10 (v1.1.0) - Fixed Window_DialogHelp class into the plugin.
 * 2016.08.16 (v1.1.1) - Added the direction property setting the direction of content flow.
 * 2016.08.16 (v1.1.1a) - Fixed a whitespace bug.
 * 2016.10.14 (v1.1.2) - Fixed the issue that is not working in Battle.
 * 2016.10.14 (v1.1.3) :
 * - Fixed the bug that does not change the background color.
 * - Fixed the bug that does not change the variable ID.
 * 2016.10.17 (v1.1.4) - Fixed the frame works of input dialog in battle.
 * 2016.10.18 (v1.1.5) - Fixed an issue that battler's movement is too fast.
 * 2016.10.29 (v1.1.6) - Added the function that allows you to specify the maximum number of character for an input field.
 * 2016.11.13 (v1.1.6a) - Fixed the issue that is directly calling the requestUpdate function of SceneManager.
 * 2016.12.02 (v1.1.6e) :
 * - Added some style codes such as a text shadow and an outline into the text box.
 * - Fixed the way that can temporarily stop attack and skill actions with an enemy when the text box is activated in the battle.
 * - It will not process the text input when the text box is not shown in the battle.
 * - In the debug mode, It adds the result value to a log window after the text input is done.
 * 2016.12.08 (v1.1.6h) - Removed the text hint window.
 * 2016.12.17 (v1.1.6i) - Fixed an issue that an integer value could not be checked due to the text type issue.
 * 2017.01.30 (v1.1.7) - Fixed an issue that is not working properly if the text dialog has a string to start with a number.
 * 2017.02.16 (v1.1.8) :
 * - Fixed incorrect position and width, height values in the text box.
 * - Added new feature that indicates the input dialog at the top position of the screen when pressing any key on your own mobile device.
 * - Added new feature that automatically returns a result of the text box if you did not press anything.
 * 2018.01.25 (v1.1.8a) - test...
 * 2018.01.30 (v1.1.9) :
 * - Added the button called 'OK'.
 * - Added the button called 'Cancel'.
 * - Removed the feature that can change the background-color of the input dialog.
 * - Fixed the issue that is not clicking the button in the mobile.
 * 2018.02.03 (v1.1.10) :
 * - Fixed the issue that is not working in RMMV 1.5.1
 * - Fixed the default value of the plugin parameter  called 'CSS'.
 * 2018.02.06 (v1.1.11) :
 * - Fixed the issue that is not working in the battle scene.
 * 2018.10.22 (v1.1.15) :
 * - 텍스트 입력 상자의 위치를 정확히 조절할 수 있는 플러그인 커맨드가 추가되었습니다.
 * - 모바일에서 키보드 레이아웃이 사라졌을 때 텍스트 입력 상자를 터치하면 키보드 레이아웃을 다시 표시할 수 있습니다.
 * - 모바일에서의 폰트 크기를 1rem(16px)로 설정하였습니다.
 * - 기본 디자인을 초록색 테마에서 검정색 테마로 변경하였습니다.
 * - 크로미움 69+ 버전에서 <input> 태그의 z-index가 <canvas> 태그의 z-index보다 낮더라도 화면에 표시되는 버그가 있었습니다.
 * 2019.03.05 (v1.1.16) :
 * - Fixed the issue that can not create a background when using Irina_PerformanceUpgrade.
 */
 
var Imported = Imported || {};
Imported.RS_InputDialog = true;
 
var RS = RS || {};
RS.InputDialog = RS.InputDialog || {};
RS.InputDialog.Params = RS.InputDialog.Params || {};
RS.Utils = RS.Utils || {};
 
function Scene_InputDialog() {
    this.initialize.apply(this, arguments);
}
 
(function () {
    var parameters = $plugins.filter(function (i) {
        return i.description.contains("<RS_InputDialog>");
    });
 
    parameters = parameters.length > 0 && parameters[0].parameters;
 
    RS.Utils.jsonParse = function (str) {
        var retData = JSON.parse(str, function (k, v) {
            try {
                return RS.Utils.jsonParse(v);
            } catch (e) {
                return v;
            }
        });
        return retData;
    };
 
    //============================================================================
    // Global Variables in RS.InputDialog
    //============================================================================
 
    RS.InputDialog.Params.textBoxWidth = Number(
        parameters["textBox Width"] || 488
    );
    RS.InputDialog.Params.textBoxHeight = Number(
        parameters["textBox Height"] || 36
    );
    RS.InputDialog.Params.variableID = Number(parameters["variable ID"] || 3);
 
    RS.InputDialog.Params.debug = Boolean(parameters["debug"] === "true");
 
    RS.InputDialog.Params.localText = String(
        parameters["Text Hint"] || "Test Message"
    );
    RS.InputDialog.Params.inputDirection = String(
        parameters["direction"] || "ltr"
    );
 
    RS.InputDialog.Params.nMaxLength = parseInt(
        parameters["Max Length"] || "6"
    );
 
    RS.InputDialog.Params.szTextBoxId = "md_textBox";
    RS.InputDialog.Params.szFieldId = "md_inputField";
 
    RS.InputDialog.Params.nCheckScreenLock = 8000;
 
    RS.InputDialog.Params.okButtonName = parameters["Ok"] || "Ok";
    RS.InputDialog.Params.cancelButtonName = parameters["Cancel"] || "Cancel";
 
    RS.InputDialog.Params.exStyle = RS.Utils.jsonParse(parameters["CSS"]);
 
    RS.InputDialog.Params.pos = new PIXI.Point(0, 0);
    RS.InputDialog.Params.isCenterAlignment = (function () {
        var position = parameters["Position"];
        position = position.trim();
        if (position === "center") {
            return true;
        }
        var reg = /(.*)[ ]*,[ ]*(.*)/i;
        if (reg.exec(position)) {
            if (RS.InputDialog.Params.pos) {
                RS.InputDialog.Params.pos.x = parseFloat(RegExp.$1);
                RS.InputDialog.Params.pos.y = parseFloat(RegExp.$2);
            }
        }
        return false;
    })();
 
    //============================================================================
    // public methods in RS.InputDialog
    //============================================================================
 
    RS.InputDialog.createInstance = function () {
        var scene = SceneManager._scene;
        if (scene instanceof Scene_Battle) {
            scene.showTextBox();
        } else {
            SceneManager.push(Scene_InputDialog);
        }
    };
 
    RS.InputDialog.setRect = function () {
        "use strict";
 
        var query, textBox, OkButton, CancelButton;
 
        query = `div#${RS.InputDialog.Params.szFieldId} table.inputDialogContainer tr td input[type=text]`;
        textBox = document.querySelector(query);
 
        query = `div#${RS.InputDialog.Params.szFieldId} table.inputDialogContainer tr td input[type=button][id=inputDialog-OkBtn]`;
        OkButton = document.querySelector(query);
 
        query = `div#${RS.InputDialog.Params.szFieldId} table.inputDialogContainer tr td input[type=button][id=inputDialog-CancelBtn]`;
        CancelButton = document.querySelector(query);
 
        if (textBox) {
            textBox.style.fontSize = Utils.isMobileDevice()
                ? "1rem"
                : 2 * Graphics._realScale + "em";
            textBox.style.width =
                RS.InputDialog.getScreenWidth(
                    RS.InputDialog.Params.textBoxWidth * Graphics._realScale
                ) + "px";
            textBox.style.height =
                RS.InputDialog.getScreenHeight(
                    RS.InputDialog.Params.textBoxHeight * Graphics._realScale
                ) + "px";
        }
 
        if (OkButton)
            OkButton.style.fontSize = Utils.isMobileDevice()
                ? "1rem"
                : 1 * Graphics._realScale + "em";
        if (CancelButton)
            CancelButton.style.fontSize = Utils.isMobileDevice()
                ? "1rem"
                : 1 * Graphics._realScale + "em";
    };
 
    RS.InputDialog.startBattleBlur = function (target, value) {
        var blur = "blur(%1px)".format(value);
        target.style.webkitFilter = blur;
        target.style.filter = blur;
    };
 
    RS.InputDialog.getScreenWidth = function (value) {
        return value;
    };
 
    RS.InputDialog.getScreenHeight = function (value) {
        return value;
    };
 
    //============================================================================
    // Input
    //============================================================================
 
    var original_Input_shouldPreventDefault = Input._shouldPreventDefault;
    var dialog_Input_shouldPreventDefault = function (keyCode) {
        switch (keyCode) {
            case 33: // pageup
            case 34: // pagedown
            case 37: // left arrow
            case 38: // up arrow
            case 39: // right arrow
            case 40: // down arrow
                return true;
        }
        return false;
    };
 
    //============================================================================
    // TextBox
    //============================================================================
 
    function TextBox() {
        this.initialize.apply(this, arguments);
    }
 
    TextBox.BACK_SPACE = 8;
    TextBox.ENTER = 13;
    TextBox.ESC = 27;
    TextBox.IS_NOT_CHAR = 32;
    TextBox.KEYS_ARRAY = 255;
 
    TextBox.prototype.initialize = function (fieldID, textBoxID) {
        this._fieldId = fieldID;
        this._textBoxID = textBoxID;
        this._lastInputTime = performance.now();
        this._ready = false;
        this.prepareElement(fieldID);
        this.createTextBox(textBoxID);
    };
 
    TextBox.prototype.startToConvertInput = function () {
        Input._shouldPreventDefault = dialog_Input_shouldPreventDefault;
    };
 
    TextBox.prototype.startToOriginalInput = function () {
        Input._shouldPreventDefault = original_Input_shouldPreventDefault;
    };
 
    TextBox.prototype.createTextBox = function (id) {
        "use strict";
 
        var self = this;
        var field = document.getElementById(this._fieldId);
 
        var style = `
    .inputDialogContainer {
      min-width : 10em;
      max-width : 2.5em;
      top : 0em;
      left : 0em;
      width : 10em;
      height : 2.5em;
      display : flex;
      flex-flow : column wrap;
      align-items : left;
      justify-content : left;
      padding : 0;
      margin : 0;
      box-sizing : border-box;
      resize : both;
      font-size: 16px!important;
  }
 
  .inputDialog {
      top : 0em;
      left : 0em;
      right : 0em;
      bottom : 0em;
      z-index : 1000;
      opacity : 0.8;
      position : relative;
      background-color : #ffffff;
      border : 2px solid #414141;
      border-radius : 10px;
      text-shadow : 0px 1px 3px #696969;
      font-family : arial;
      color : #1a1a1a;
      outline : none;
      font-size: 1rem!important;
  }
 
  .defaultButton {
      opacity : 0.8;
      font-family : arial;
      border : 1px solid rgb(73, 73, 73);
      background-image: -webkit-linear-gradient(top, rgba(255,255,255,.2) 0%, rgba(255,255,255,0) 100%);
      color : rgb(19, 19, 19);
      text-shadow : rgba(105, 105, 105, 0.7) 0 1px 0;
      cursor : pointer;
      border-radius : 0.5em;
      box-sizing : border-box;
      box-shadow : 0 1px 4px rgba(78, 78, 78, 0.6);
      font-size : 1rem!important;
  }
 
  .row {
      width : 70%;
      height: 1rem;
  }
 
  .col {
      width : 70%;
      height: 1rem;
  }
 
  @media screen and (min-width : 192px) and (max-width : 768px) {
      .defaultButton {
          font-size : 1rem!important;
      }
      .row {
          width : 100%;
          height: 2rem;
      }
      .col {
          width : 100%;
          height: 2rem;
      }
      .inputDialog {
          font-size : 1rem!important;
      }
  }
 
  @media screen and (min-width : 768px) and (max-width : 1000px) {
      .defaultButton {
          font-size : 1rem!important;
      }
      .row {
          width : 100%;
          height: 2rem;
      }
      .col {
          width : 100%;
          height: 2rem;
      }
      .inputDialog {
          font-size : 1rem!important;
      }
  }
	  `;
 
        var exStyle = RS.InputDialog.Params.exStyle;
 
        var divInnerHTML = `
    <style>
    ${style}
    ${exStyle}
    .inputDialog {
      direction : ${RS.InputDialog.Params.inputDirection};
    }
    </style>
    <table class="inputDialogContainer">
  		<tr class="row">
  			<td class="col">
  				<input class="inputDialog" type="text" id"=${id} placeholder="${RS.InputDialog.Params.localText}">
  			</td>
  		</tr>
  		<tr class="row" valign="bottom">
  			<td class="col" align="right">
  				<input class="defaultButton" id="inputDialog-OkBtn" type="button" value="${RS.InputDialog.Params.okButtonName}" name="">
          <input class="defaultButton" id="inputDialog-CancelBtn" type="button" value="${RS.InputDialog.Params.cancelButtonName}" name="">
  			</td>
  		</tr>
    <img src='' onload='TextBox.onLoadAfterInnerHTML();this.parentNode.removeChild(this);'>
  	</table>
    `;
 
        field.innerHTML = divInnerHTML;
    };
 
    TextBox.onLoadAfterInnerHTML = function () {
        if (SceneManager._scene) {
            if (SceneManager._scene instanceof Scene_InputDialog) {
                if (SceneManager._scene._textBox) {
                    SceneManager._scene._textBox.addAllEventListener();
                }
            }
        }
    };
 
    TextBox.prototype.getTextBoxId = function () {
        "use strict";
        var query = `div#${RS.InputDialog.Params.szFieldId} table.inputDialogContainer tr td input[type=text]`;
        return document.querySelector(query);
    };
 
    TextBox.prototype.getDefaultButtonId = function (id) {
        "use strict";
        id = id || "inputDialog-OkBtn";
        var query = `div#${RS.InputDialog.Params.szFieldId} table.inputDialogContainer tr td input[type=button][id=${id}]`;
        return document.querySelector(query);
    };
 
    TextBox.prototype.getMainContainer = function () {
        "use strict";
        var query = `div#${RS.InputDialog.Params.szFieldId} table.inputDialogContainer`;
        return document.querySelector(query);
    };
 
    TextBox.prototype.addAllEventListener = function () {
        this._textBox = this.getTextBoxId();
        this._textBox.maxLength = RS.InputDialog.Params.nMaxLength;
        this._textBox.max = RS.InputDialog.Params.nMaxLength;
 
        this._textBox.addEventListener(
            "keydown",
            this.onKeyDown.bind(this),
            false
        );
        if (!Utils.isMobileDevice()) {
            this._textBox.addEventListener(
                "focus",
                this.onFocus.bind(this),
                false
            );
        }
        this._textBox.addEventListener("blur", this.onBlur.bind(this), false);
        this._textBox.addEventListener(
            "touchstart",
            this.getFocus.bind(this),
            false
        );
        this._textBox.addEventListener(
            "autosize",
            this.onResize.bind(this),
            false
        );
 
        window.addEventListener("resize", this.onResize.bind(this), false);
 
        this.startToConvertInput();
        this.setRect();
        this.onResize();
 
        if (SceneManager._scene instanceof Scene_InputDialog) {
            this.getFocus();
            this.show();
        }
 
        this._ready = true;
    };
 
    TextBox.prototype.setRect = function () {
        var textBox = this.getTextBoxId();
        var OkButton = this.getDefaultButtonId("inputDialog-OkBtn");
        var CancelButton = this.getDefaultButtonId("inputDialog-CancelBtn");
 
        if (OkButton)
            OkButton.style.fontSize = Utils.isMobileDevice()
                ? "1rem"
                : 1 * Graphics._realScale + "em";
        if (CancelButton)
            CancelButton.style.fontSize = Utils.isMobileDevice()
                ? "1rem"
                : 1 * Graphics._realScale + "em";
 
        textBox.style.fontSize = Utils.isMobileDevice()
            ? "1rem"
            : 2 * Graphics._realScale + "em";
        textBox.style.width =
            RS.InputDialog.getScreenWidth(
                RS.InputDialog.Params.textBoxWidth * Graphics._realScale
            ) + "px";
        textBox.style.height =
            RS.InputDialog.getScreenHeight(
                RS.InputDialog.Params.textBoxHeight * Graphics._realScale
            ) + "px";
    };
 
    TextBox.prototype.prepareElement = function (id) {
        var field = document.createElement("div");
        field.id = id;
        field.style.position = "absolute";
        field.style.left = "0";
        field.style.top = "0";
        field.style.right = "0";
        field.style.bottom = "0";
        field.style.width = "100%";
        field.style.height = "100%";
        field.style.zIndex = "0";
        field.style.display = "none"; // there is a bug occurs in nwjs 0.33.4
        document.body.appendChild(field);
        if (RS.InputDialog.Params.isCenterAlignment) {
            Graphics._centerElement(field);
        }
        return field;
    };
 
    TextBox.prototype.setEvent = function (okFunc, cancelFunc) {
        var okButton = this.getDefaultButtonId("inputDialog-OkBtn");
        var cancelButton = this.getDefaultButtonId("inputDialog-CancelBtn");
        okButton.addEventListener(
            "click",
            function (e) {
                okFunc();
                e.preventDefault();
            },
            false
        );
        cancelButton.addEventListener(
            "click",
            function (e) {
                cancelFunc();
                e.preventDefault();
            },
            false
        );
        okButton.addEventListener(
            "touchend",
            function (e) {
                okFunc();
                e.preventDefault();
            },
            false
        );
        cancelButton.addEventListener(
            "touchend",
            function (e) {
                cancelFunc();
                e.preventDefault();
            },
            false
        );
 
        this._okFunc = okFunc;
        this._cancelFunc = cancelFunc;
    };
 
    TextBox.prototype.terminateTextBox = function () {
        var field = document.getElementById(this._fieldId);
 
        if (field) {
            document.body.removeChild(field);
        }
 
        this.startToOriginalInput();
    };
 
    TextBox.prototype.onKeyDown = function (e) {
        var keyCode = e.which;
        if (keyCode < TextBox.IS_NOT_CHAR) {
            if (keyCode === TextBox.ENTER) {
                if (this._okFunc instanceof Function) this._okFunc();
            }
            if (keyCode === TextBox.ESC) {
                if (this._cancelFunc instanceof Function) this._cancelFunc();
            }
        }
 
        this._lastInputTime = performance.now();
    };
 
    TextBox.prototype.onFocus = function (e) {
        var text = this.getTextBoxId();
        if (text && Utils.isMobileDevice()) {
            text.style.bottom =
                RS.InputDialog.getScreenHeight(Graphics.boxHeight / 2) + "px";
        }
    };
 
    TextBox.prototype.onBlur = function (e) {
        var text = this.getTextBoxId();
        if (text && Utils.isMobileDevice()) {
            text.style.bottom = "0";
            text.focus();
        }
        e.preventDefault();
    };
 
    TextBox.prototype.setPosition = function (x, y) {
        var self = this;
        var field = document.getElementById(self._fieldId);
        var textBox = self.getTextBoxId();
        var mainContainer = self.getMainContainer();
        if (field) {
            field.style.margin = "0";
            mainContainer.style.margin = "0";
            if (x < 0) {
                x = 0;
            }
            if (x > Graphics.boxWidth - RS.InputDialog.Params.textBoxWidth) {
                x = Graphics.boxWidth - RS.InputDialog.Params.textBoxWidth;
            }
            if (y < 0) {
                y = 0;
            }
            if (y > Graphics.boxHeight - RS.InputDialog.Params.textBoxHeight) {
                y = Graphics.boxHeight - RS.InputDialog.Params.textBoxHeight;
            }
            mainContainer.style.left =
                Graphics._canvas.getBoundingClientRect().left + x + "px";
            mainContainer.style.top =
                Graphics._canvas.getBoundingClientRect().top + y + "px";
        }
    };
 
    TextBox.prototype.onResize = function () {
        var self = this;
        var field = document.getElementById(self._fieldId);
        var textBox = self.getTextBoxId();
        var mainContainer = self.getMainContainer();
        if (field && textBox) {
            Graphics._centerElement(field);
            Graphics._centerElement(mainContainer);
            this.setRect();
 
            if (RS.InputDialog.Params.isCenterAlignment) {
                var px =
                    Graphics.boxWidth / 2 -
                    RS.InputDialog.Params.textBoxWidth / 2;
                var py =
                    Graphics.boxHeight / 2 -
                    RS.InputDialog.Params.textBoxHeight / 2;
                this.setPosition(px, py);
            } else {
                this.setPosition(
                    RS.InputDialog.Params.pos.x,
                    RS.InputDialog.Params.pos.y
                );
            }
        }
    };
 
    TextBox.prototype.isScreenLock = function () {
        var val = parseInt(performance.now() - this._lastInputTime);
        var ret = false;
        if (val >= RS.InputDialog.Params.nCheckScreenLock && this.isBusy())
            ret = true;
        this._lastInputTime = performance.now();
        return ret;
    };
 
    TextBox.prototype.getTextLength = function () {
        var textBox = this.getTextBoxId();
        return textBox.value.length;
    };
 
    TextBox.prototype.getFocus = function () {
        var textBox = this.getTextBoxId();
        textBox.focus();
    };
 
    TextBox.prototype.setText = function (text) {
        var textBox = this.getTextBoxId();
        textBox.value = text || "";
        return textBox;
    };
 
    TextBox.prototype.getText = function () {
        var textBox = this.getTextBoxId();
        return textBox.value;
    };
 
    TextBox.prototype.hide = function () {
        var field = document.getElementById(this._fieldId);
        field.style.zIndex = 0;
        field.style.display = "none"; // for 0.33.4
    };
 
    TextBox.prototype.show = function () {
        var field = document.getElementById(this._fieldId);
        field.style.zIndex = 1000;
        field.style.display = "block"; // for 0.33.4
    };
 
    TextBox.prototype.setTextHint = function () {
        var textBox = this.getTextBoxId();
        return (textBox.placeholder = RS.InputDialog.Params.localText);
    };
 
    TextBox.prototype.isBusy = function () {
        var field = document.getElementById(this._fieldId);
        return field.style.zIndex > 0;
    };
 
    TextBox.prototype.removeAllEventListener = function () {
        this._okFunc = null;
        this._cancelFunc = null;
 
        if (this._textBox) {
            this._textBox.outerHTML = this._textBox.outerHTML;
        }
 
        window.removeEventListener("resize", this.onResize.bind(this), false);
    };
 
    TextBox.prototype.terminate = function () {
        this.removeAllEventListener();
        this.terminateTextBox();
    };
 
    //============================================================================
    // Scene_InputDialog
    //============================================================================
 
    Scene_InputDialog.prototype = Object.create(Scene_Base.prototype);
    Scene_InputDialog.prototype.constructor = Scene_InputDialog;
 
    Scene_InputDialog.prototype.initialize = function () {
        Scene_Base.prototype.initialize.call(this);
    };
 
    Scene_InputDialog.prototype.create = function () {
        Scene_Base.prototype.create.call(this);
        this.createBackground();
        this.createTextBox();
    };
 
    var alias_Scene_InputDialog_update = Scene_InputDialog.prototype.update;
    Scene_InputDialog.prototype.update = function () {
        alias_Scene_InputDialog_update.call(this);
        // TODO: 모바일에서 취소키를 누르면 키입력 창이 사라지는 버그가 있다.
        // 그래서 추가했지만 화면을 누르면 꺼진다는 것을 모르는 유저들이 버그로 착각할 수 있다.
        if (this.isScreenLock() && TouchInput.isTriggered()) {
            this.okResult();
        }
    };
 
    Scene_InputDialog.prototype.terminate = function () {
        Scene_Base.prototype.terminate.call(this);
        this._textBox.terminate();
        this._textBox = null;
    };
 
    Scene_InputDialog.prototype.isScreenLock = function () {
        return this._textBox.isScreenLock();
    };
 
    Scene_InputDialog.prototype.createBackground = function () {
        if (Imported.Irina_PerformanceUpgrade) {
            Scene_MenuBase.prototype.createBackground.call(this);
        } else {
            this._backgroundSprite = new Sprite();
            this._backgroundSprite.bitmap = SceneManager.backgroundBitmap();
            this._backgroundSprite.opacity = 128;
            this.addChild(this._backgroundSprite);
        }
    };
 
    Scene_InputDialog.prototype.createTextBox = function () {
        this._textBox = new TextBox(
            RS.InputDialog.Params.szFieldId,
            RS.InputDialog.Params.szTextBoxId
        );
        this._textBox.setEvent(
            this.okResult.bind(this),
            this.cancelResult.bind(this)
        );
        this._textBox.show();
        this._textBox.setTextHint();
    };
 
    Scene_InputDialog.prototype.okResult = function () {
        var text = this._textBox.getText() || "";
        if (text.match(/^([\d]+)$/g)) text = Number(RegExp.$1);
        $gameVariables.setValue(RS.InputDialog.Params.variableID, text);
        if (SceneManager._stack.length > 0) {
            TouchInput.clear();
            Input.clear();
            this.popScene();
        }
    };
 
    Scene_InputDialog.prototype.cancelResult = function () {
        if (SceneManager._stack.length > 0) {
            TouchInput.clear();
            Input.clear();
            this.popScene();
        }
    };
 
    //============================================================================
    // Game_Troop
    //============================================================================
 
    Game_Troop.prototype.battleInterpreterTaskLock = function () {
        this._interpreter._waitMode = "IME Mode";
    };
 
    Game_Troop.prototype.battleInterpreterTaskUnlock = function () {
        this._interpreter._waitMode = "";
    };
 
    //============================================================================
    // Scene_Battle
    //============================================================================
 
    var alias_Scene_Battle_initialize = Scene_Battle.prototype.initialize;
    Scene_Battle.prototype.initialize = function () {
        alias_Scene_Battle_initialize.call(this);
        this.createTextBox();
    };
 
    var alias_Scene_Battle_create = Scene_Battle.prototype.create;
    Scene_Battle.prototype.create = function () {
        alias_Scene_Battle_create.call(this);
    };
 
    var alias_Scene_Battle_update = Scene_Battle.prototype.update;
    Scene_Battle.prototype.update = function () {
        alias_Scene_Battle_update.call(this);
        // TODO: 모바일에서 취소키를 누르면 키입력 창이 사라지는 버그가 있다.
        // 그래서 추가했지만 화면을 누르면 꺼진다는 것을 모르는 유저들이 버그로 착각할 수 있다.
        if (this.isScreenLock() && TouchInput.isTriggered()) {
            this.okResult();
        }
    };
 
    var alias_Scene_Battle_terminate = Scene_Battle.prototype.terminate;
    Scene_Battle.prototype.terminate = function () {
        alias_Scene_Battle_terminate.call(this);
        if (this._textBox) {
            this._textBox.terminate();
            this._textBox = null;
        }
        if ($gameTemp.isCommonEventReserved()) {
            $gameTemp.clearCommonEvent();
        }
    };
 
    Scene_Battle.prototype.createTextBox = function () {
        this._textBox = new TextBox(
            RS.InputDialog.Params.szFieldId,
            RS.InputDialog.Params.szTextBoxId
        );
        this._textBox.setEvent(
            this.okResult.bind(this),
            this.cancelResult.bind(this)
        );
    };
 
    Scene_Battle.prototype.textBoxIsBusy = function () {
        return this._textBox.isBusy();
    };
 
    Scene_Battle.prototype.showTextBox = function () {
        this._textBox.setText("");
        this._textBox.show();
        this._textBox.getFocus();
        this._textBox.setTextHint();
        this._textBox.setRect();
        this._textBox.onResize();
        $gameTroop.battleInterpreterTaskLock();
        this._textBox.addAllEventListener();
    };
 
    Scene_Battle.prototype.hideTextBox = function () {
        if (!this.textBoxIsBusy()) return false;
        this._textBox.hide();
        Input.clear();
        $gameTroop.battleInterpreterTaskUnlock();
    };
 
    Scene_Battle.prototype.isScreenLock = function () {
        return this._textBox.isScreenLock();
    };
 
    Scene_Battle.prototype.okResult = function () {
        if (!this._textBox) return "";
        if (this.textBoxIsBusy()) {
            var text = this._textBox.getText() || "";
            if (text.match(/^([\d]+)$/g)) text = Number(RegExp.$1);
            $gameVariables.setValue(RS.InputDialog.Params.variableID, text);
            this._textBox.setText("");
            if (RS.InputDialog.Params.debug) {
                var dmsg = "You typed the text is same as ".concat(
                    $gameVariables.value(RS.InputDialog.Params.variableID) +
                        "" || "NONE"
                );
                this._logWindow.push("addText", dmsg);
            }
            this.hideTextBox();
        }
    };
 
    Scene_Battle.prototype.cancelResult = function () {
        if (!this._textBox) return "";
        if (this.textBoxIsBusy()) {
            this._textBox.setText("");
            this.hideTextBox();
        }
    };
 
    //============================================================================
    // Game_Interpreter
    //============================================================================
 
    var alias_Game_Interpreter_updateWaitMode =
        Game_Interpreter.prototype.updateWaitMode;
    Game_Interpreter.prototype.updateWaitMode = function () {
        if (this._waitMode === "IME Mode") {
            return true;
        } else {
            return alias_Game_Interpreter_updateWaitMode.call(this);
        }
    };
 
    RS.InputDialog.isEqual = function (eq) {
        var data = String(
            $gameVariables.value(RS.InputDialog.Params.variableID)
        );
        eq = String(eq);
        return data === eq;
    };
 
    Game_Interpreter.prototype.isEqualInputData = function (eq) {
        return RS.InputDialog.isEqual(eq);
    };
 
    var alias_Game_Interpreter_pluginCommand =
        Game_Interpreter.prototype.pluginCommand;
    Game_Interpreter.prototype.pluginCommand = function (command, args) {
        alias_Game_Interpreter_pluginCommand.call(this, command, args);
        if (command === "InputDialog") {
            switch (args[0]) {
                case "open":
                    RS.InputDialog.createInstance();
                    break;
                case "width":
                    RS.InputDialog.Params.textBoxWidth = Number(args[1] || 488);
                    RS.InputDialog.setRect();
                    break;
                case "text":
                    RS.InputDialog.Params.localText = args
                        .slice(1, args.length)
                        .join(" ");
                    break;
                case "variableID":
                    RS.InputDialog.Params.variableID = Number(args[1] || 3);
                    break;
                case "debug":
                    RS.InputDialog.Params.debug = Boolean(args[1] === "true");
                    break;
                case "maxLength":
                    RS.InputDialog.Params.nMaxLength = Number(args[1] || 255);
                    RS.InputDialog.setRect();
                    break;
                case "pos":
                    if (args[1] === "center") {
                        RS.InputDialog.Params.isCenterAlignment = true;
                    } else {
                        RS.InputDialog.Params.isCenterAlignment = false;
                        RS.InputDialog.Params.pos.x = parseFloat(args[1] || 0);
                        RS.InputDialog.Params.pos.y = parseFloat(args[2] || 0);
                    }
                    break;
            }
        }
    };
 
    if (Utils.RPGMAKER_NAME != "MV") {
        PluginManager.registerCommand(
            "RS_InputDialog",
            "InputDialogOpen",
            () => {
                RS.InputDialog.createInstance();
            }
        );
 
        PluginManager.registerCommand(
            "RS_InputDialog",
            "InputDialogWidth",
            (args) => {
                RS.InputDialog.Params.textBoxWidth = Number(args.width || 488);
                RS.InputDialog.setRect();
            }
        );
 
        PluginManager.registerCommand(
            "RS_InputDialog",
            "InputDialogText",
            (args) => {
                RS.InputDialog.Params.localText = args.text || "";
            }
        );
 
        PluginManager.registerCommand(
            "RS_InputDialog",
            "InputDialogVariableID",
            (args) => {
                RS.InputDialog.Params.variableID = Number(args.variableID || 3);
            }
        );
 
        PluginManager.registerCommand(
            "RS_InputDialog",
            "InputDialogDebug",
            (args) => {
                RS.InputDialog.Params.debug = Boolean(args.isDebug === "true");
            }
        );
 
        PluginManager.registerCommand(
            "RS_InputDialog",
            "InputDialogMaxLength",
            (args) => {
                RS.InputDialog.Params.nMaxLength = Number(
                    args.maxLength || 255
                );
                RS.InputDialog.setRect();
            }
        );
 
        PluginManager.registerCommand(
            "RS_InputDialog",
            "InputDialogPos",
            (args) => {
                if (args.pos === "center") {
                    RS.InputDialog.Params.isCenterAlignment = true;
                } else {
                    RS.InputDialog.Params.isCenterAlignment = false;
                    RS.InputDialog.Params.pos.x = parseFloat(args.posX || 0);
                    RS.InputDialog.Params.pos.y = parseFloat(args.posY || 0);
                }
            }
        );
 
        PluginManager.registerCommand(
            "RS_InputDialog",
            "InputDialogButtonOK",
            (args) => {
                RS.InputDialog.Params.okButtonName = args.text || "Ok";
            }
        );
 
        PluginManager.registerCommand(
            "RS_InputDialog",
            "InputDialogButtonCancel",
            (args) => {
                RS.InputDialog.Params.cancelButtonName = args.text || "Cancel";
            }
        );
    }
 
    window.TextBox = TextBox;
})();
Вот Window игры:

Window-2.png


Необязательно прям под него. Просто чтоб сочеталась.
Скриншот из игры:

2022-06-11205113.png


С меня благодарность и упоминание в тирах игры.
Пожалуйста, если кого не затруднит.
Мой вк: vk.com/borisov_alexandr_5
Мой ютуб канал: www.youtube.com/@alexandr_5836
Мой бусти: boosty.to/alexandr-7
Администратор запретил публиковать записи гостям.

CSS дизайн для RS_InputDialog 1 год 10 мес. назад #127158

  • Безликий
  • Безликий аватар
  • Вне сайта
  • Просветлённый
  • Сообщений: 315
  • Спасибо получено: 355
  • 2 место в Обучающем конкурсеПоддержка ФондаДаритель СтимкеяУчитель
Чегож ты не прикрепил скрин с тем, как плагин выводит то эти диалоги. Чтобы хоть увидеть итоговый результат и разницу между Window и этим результатом.

В целом, вроде-как ничего страшного в стилях там нет.
Администратор запретил публиковать записи гостям.

CSS дизайн для RS_InputDialog 1 год 10 мес. назад #127160

  • Alexandr_7
  • Alexandr_7 аватар
  • Вне сайта
  • Архитектор Миров
  • Сообщений: 1185
  • Спасибо получено: 539
  • УчительВетеранПроект месяца 3 местоПроект года 3 местоПроект месяца 2 местоПроект месяца 1 место
Безликий пишет:
Чегож ты не прикрепил скрин с тем, как плагин выводит то эти диалоги. Чтобы хоть увидеть итоговый результат и разницу между Window и этим результатом.

В целом, вроде-как ничего страшного в стилях там нет.

Да. Както забыл. Вот как выводит:

2022-06-12142545.png


И ещё отдельно сам стиль CSS из кода плагина:
TextBox.prototype.createTextBox = function (id) {
        "use strict";
 
        var self = this;
        var field = document.getElementById(this._fieldId);
 
        var style = `
    .inputDialogContainer {
      min-width : 10em;
      max-width : 2.5em;
      top : 0em;
      left : 0em;
      width : 10em;
      height : 2.5em;
      display : flex;
      flex-flow : column wrap;
      align-items : left;
      justify-content : left;
      padding : 0;
      margin : 0;
      box-sizing : border-box;
      resize : both;
      font-size: 16px!important;
  }
 
  .inputDialog {
      top : 0em;
      left : 0em;
      right : 0em;
      bottom : 0em;
      z-index : 1000;
      opacity : 0.8;
      position : relative;
      background-color : #ffffff;
      border : 2px solid #414141;
      border-radius : 10px;
      text-shadow : 0px 1px 3px #696969;
      font-family : arial;
      color : #1a1a1a;
      outline : none;
      font-size: 1rem!important;
  }
 
  .defaultButton {
      opacity : 0.8;
      font-family : arial;
      border : 1px solid rgb(73, 73, 73);
      background-image: -webkit-linear-gradient(top, rgba(255,255,255,.2) 0%, rgba(255,255,255,0) 100%);
      color : rgb(19, 19, 19);
      text-shadow : rgba(105, 105, 105, 0.7) 0 1px 0;
      cursor : pointer;
      border-radius : 0.5em;
      box-sizing : border-box;
      box-shadow : 0 1px 4px rgba(78, 78, 78, 0.6);
      font-size : 1rem!important;
  }
 
  .row {
      width : 70%;
      height: 1rem;
  }
 
  .col {
      width : 70%;
      height: 1rem;
  }
 
  @media screen and (min-width : 192px) and (max-width : 768px) {
      .defaultButton {
          font-size : 1rem!important;
      }
      .row {
          width : 100%;
          height: 2rem;
      }
      .col {
          width : 100%;
          height: 2rem;
      }
      .inputDialog {
          font-size : 1rem!important;
      }
  }
 
  @media screen and (min-width : 768px) and (max-width : 1000px) {
      .defaultButton {
          font-size : 1rem!important;
      }
      .row {
          width : 100%;
          height: 2rem;
      }
      .col {
          width : 100%;
          height: 2rem;
      }
      .inputDialog {
          font-size : 1rem!important;
      }
  }
	  `;
 
        var exStyle = RS.InputDialog.Params.exStyle;
 
        var divInnerHTML = `
    <style>
    ${style}
    ${exStyle}
    .inputDialog {
      direction : ${RS.InputDialog.Params.inputDirection};
    }
    </style>
    <table class="inputDialogContainer">
  		<tr class="row">
  			<td class="col">
  				<input class="inputDialog" type="text" id"=${id} placeholder="${RS.InputDialog.Params.localText}">
  			</td>
  		</tr>
  		<tr class="row" valign="bottom">
  			<td class="col" align="right">
  				<input class="defaultButton" id="inputDialog-OkBtn" type="button" value="${RS.InputDialog.Params.okButtonName}" name="">
          <input class="defaultButton" id="inputDialog-CancelBtn" type="button" value="${RS.InputDialog.Params.cancelButtonName}" name="">
  			</td>
  		</tr>
    <img src='' onload='TextBox.onLoadAfterInnerHTML();this.parentNode.removeChild(this);'>
  	</table>
    `;
 
        field.innerHTML = divInnerHTML;
    };
Мой вк: vk.com/borisov_alexandr_5
Мой ютуб канал: www.youtube.com/@alexandr_5836
Мой бусти: boosty.to/alexandr-7
Последнее редактирование: 1 год 10 мес. назад от Alexandr_7.
Администратор запретил публиковать записи гостям.

CSS дизайн для RS_InputDialog 1 год 10 мес. назад #127163

  • Alexandr_7
  • Alexandr_7 аватар
  • Вне сайта
  • Архитектор Миров
  • Сообщений: 1185
  • Спасибо получено: 539
  • УчительВетеранПроект месяца 3 местоПроект года 3 местоПроект месяца 2 местоПроект месяца 1 место
Спасибо огромное "Безликий"/ Помог мне в ВК. Вопрос решён:

2022-06-12220855.png
Мой вк: vk.com/borisov_alexandr_5
Мой ютуб канал: www.youtube.com/@alexandr_5836
Мой бусти: boosty.to/alexandr-7
Администратор запретил публиковать записи гостям.
Время создания страницы: 0.304 секунд