├── .gitignore ├── Blank_ChromaLink.chroma ├── Blank_Headset.chroma ├── Blank_Keyboard.chroma ├── Blank_Keypad.chroma ├── Blank_Mouse.chroma ├── Blank_Mousepad.chroma ├── ChromaLinkEffects.js ├── ChromaSDKImpl.js ├── Colors.html ├── EnvironmentSnow_Keyboard.chroma ├── FadeInOutGray_ChromaLink.chroma ├── FadeInOutGray_Headset.chroma ├── FadeInOutGray_Keyboard.chroma ├── FadeInOutGray_Keypad.chroma ├── FadeInOutGray_Mouse.chroma ├── FadeInOutGray_Mousepad.chroma ├── FireEffect_ChromaLink.chroma ├── FireEffect_Headset.chroma ├── FireEffect_Keyboard.chroma ├── FireEffect_Keypad.chroma ├── FireEffect_Mouse.chroma ├── FireEffect_Mousepad.chroma ├── HeadsetEffects.js ├── KeyboardEffects.js ├── KeypadEffects.js ├── LICENSE ├── LayerSample.html ├── ModalDlg.css ├── MouseEffects.js ├── MousematEffects.js ├── PlayAnimationSample.html ├── README.md ├── Random_ChromaLink.chroma ├── Random_Headset.chroma ├── Random_Keyboard.chroma ├── Random_Keypad.chroma ├── Random_Mouse.chroma ├── Random_Mousepad.chroma ├── RazerChromaSDKSampleApplication.html ├── RazerGreen_ChromaLink.chroma ├── RazerGreen_Headset.chroma ├── RazerGreen_Keyboard.chroma ├── RazerGreen_Keypad.chroma ├── RazerGreen_Mouse.chroma ├── RazerGreen_Mousepad.chroma ├── RingGray_ChromaLink.chroma ├── RingGray_Headset.chroma ├── RingGray_Keyboard.chroma ├── RingGray_Keypad.chroma ├── RingGray_Mouse.chroma ├── RingGray_Mousepad.chroma ├── ScriptInstallServer.cmd ├── ScriptStartServer.cmd ├── ServerNode.js ├── TabbedDlg.css ├── Template.html ├── Template.js ├── Wave_ChromaLink.chroma ├── Wave_Headset.chroma ├── Wave_Keyboard.chroma ├── Wave_Keypad.chroma ├── Wave_Mouse.chroma ├── Wave_Mousepad.chroma ├── favicon.ico ├── images ├── image_1.png ├── image_2.png ├── image_3.png ├── image_4.png └── image_5.png ├── index.html ├── jquery-3.3.1.min.js └── package.json /.gitignore: -------------------------------------------------------------------------------- 1 | node_modules/ 2 | package-lock.json 3 | -------------------------------------------------------------------------------- /Blank_ChromaLink.chroma: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/razerofficial/HTML5ChromaSDK/ec61d7a1924a6facc0e136a84a00b8b87f7ce4ba/Blank_ChromaLink.chroma -------------------------------------------------------------------------------- /Blank_Headset.chroma: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/razerofficial/HTML5ChromaSDK/ec61d7a1924a6facc0e136a84a00b8b87f7ce4ba/Blank_Headset.chroma -------------------------------------------------------------------------------- /Blank_Keyboard.chroma: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/razerofficial/HTML5ChromaSDK/ec61d7a1924a6facc0e136a84a00b8b87f7ce4ba/Blank_Keyboard.chroma -------------------------------------------------------------------------------- /Blank_Keypad.chroma: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/razerofficial/HTML5ChromaSDK/ec61d7a1924a6facc0e136a84a00b8b87f7ce4ba/Blank_Keypad.chroma -------------------------------------------------------------------------------- /Blank_Mouse.chroma: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/razerofficial/HTML5ChromaSDK/ec61d7a1924a6facc0e136a84a00b8b87f7ce4ba/Blank_Mouse.chroma -------------------------------------------------------------------------------- /Blank_Mousepad.chroma: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/razerofficial/HTML5ChromaSDK/ec61d7a1924a6facc0e136a84a00b8b87f7ce4ba/Blank_Mousepad.chroma -------------------------------------------------------------------------------- /ChromaLinkEffects.js: -------------------------------------------------------------------------------- 1 | // JavaScript source code 2 | 3 | function ChromaLinkEffects() { 4 | this.loadingFrames = false; 5 | this.loadingFrame1; 6 | this.loadingFrame2; 7 | this.loadingFrame3; 8 | this.loadingFrame4; 9 | this.loadingFrame5; 10 | 11 | this.alertFrames = false; 12 | this.positiveAlert; 13 | this.negativeAlert; 14 | this.noAlert; 15 | 16 | this.damageFrames = false; 17 | this.damageOn; 18 | this.damageOff; 19 | } 20 | 21 | ChromaLinkEffects.prototype = { 22 | createLoadingAnimation: function () { 23 | chromaSDK.createChromaLinkEffect("CHROMA_NONE"); 24 | 25 | sleep(500); 26 | 27 | var color = new Array(5); 28 | for (i = 0; i < 5; i++) color[i] = 0; 29 | 30 | for (i = 0; i < 5; i++) { 31 | color[i] = 0xa5ff; 32 | 33 | chromaSDK.createChromaLinkEffect("CHROMA_CUSTOM", color); 34 | 35 | sleep(50); 36 | } 37 | }, 38 | createHealthAmmoMana: function (type, value){ 39 | var steps = Math.ceil(value / 100.0 * 5); 40 | 41 | var data = new Array(5); 42 | for (i = 0; i < 5; i++) { 43 | data[i] = 0; 44 | } 45 | 46 | if (type == 1) { // Health 47 | var green = (value / 100.0) * 0xff; 48 | var red = 0xff - ((value / 100.0) * 0xff); 49 | var color = (green) << 8 | red; 50 | 51 | for (i = 0; i < steps; i++) { 52 | data[0] = color; 53 | } 54 | } else if (type == 2) { // Ammo 55 | for (i = 1; i < steps; i++) { 56 | data[i] = 0xffff; 57 | } 58 | } 59 | 60 | chromaSDK.createChromaLinkEffect("CHROMA_CUSTOM", data); 61 | }, 62 | createAlerts: function(type) { 63 | 64 | if (this.alertFrames == false) { 65 | this.positiveAlert = chromaSDK.preCreateChromaLinkEffect("CHROMA_STATIC", 0xff00); 66 | this.negativeAlert = chromaSDK.preCreateChromaLinkEffect("CHROMA_STATIC", 0xff); 67 | this.noAlert = chromaSDK.preCreateChromaLinkEffect("CHROMA_NONE"); 68 | this.alertFrames = true; 69 | } 70 | 71 | if (type == 1) { 72 | chromaSDK.setEffect(this.noAlert); 73 | 74 | sleep(200); 75 | 76 | chromaSDK.setEffect(this.positiveAlert); 77 | 78 | sleep(200); 79 | 80 | chromaSDK.setEffect(this.noAlert); 81 | 82 | sleep(200); 83 | 84 | chromaSDK.setEffect(this.positiveAlert); 85 | 86 | sleep(200); 87 | 88 | chromaSDK.setEffect(this.noAlert); 89 | 90 | sleep(200); 91 | 92 | chromaSDK.setEffect(this.positiveAlert); 93 | 94 | sleep(200); 95 | 96 | chromaSDK.setEffect(this.noAlert); 97 | 98 | 99 | } else if (type == 0) { 100 | 101 | chromaSDK.setEffect(this.noAlert); 102 | 103 | sleep(200); 104 | 105 | chromaSDK.setEffect(this.negativeAlert); 106 | 107 | sleep(200); 108 | 109 | chromaSDK.setEffect(this.noAlert); 110 | 111 | sleep(200); 112 | 113 | chromaSDK.setEffect(this.negativeAlert); 114 | 115 | sleep(200); 116 | 117 | chromaSDK.setEffect(this.noAlert); 118 | 119 | sleep(200); 120 | 121 | chromaSDK.setEffect(this.negativeAlert); 122 | 123 | sleep(200); 124 | 125 | chromaSDK.setEffect(this.noAlert); 126 | } 127 | }, 128 | createDamageTaken: function () { 129 | if (this.damageFrames == false) { 130 | this.damageOn = chromaSDK.preCreateChromaLinkEffect("CHROMA_STATIC", 0xff); 131 | 132 | this.damageOff = chromaSDK.preCreateChromaLinkEffect("CHROMA_NONE"); 133 | this.damageFrames = true; 134 | } 135 | 136 | chromaSDK.setEffect(this.damageOn); 137 | 138 | sleep(50); 139 | 140 | chromaSDK.setEffect(this.damageOff); 141 | }, 142 | free: function() { 143 | if (this.loadingFrames == true) { 144 | chromaSDK.deleteEffect(this.loadingFrame1); 145 | chromaSDK.deleteEffect(this.loadingFrame2); 146 | chromaSDK.deleteEffect(this.loadingFrame3); 147 | chromaSDK.deleteEffect(this.loadingFrame4); 148 | chromaSDK.deleteEffect(this.loadingFrame5); 149 | this.loadingFrames = false; 150 | } 151 | 152 | if (this.alertFrames == true) { 153 | chromaSDK.deleteEffect(this.positiveAlert); 154 | chromaSDK.deleteEffect(this.negativeAlert); 155 | chromaSDK.deleteEffect(this.noAlert); 156 | this.alertFrames = false; 157 | } 158 | 159 | if (this.damageFrames == true) { 160 | chromaSDK.deleteEffect(this.damageOn); 161 | chromaSDK.deleteEffect(this.damageOff); 162 | this.damageFrames = false; 163 | } 164 | } 165 | } 166 | -------------------------------------------------------------------------------- /Colors.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 96 | 97 | 98 | 99 |
100 |
101 |
102 |
103 | 104 | 105 | -------------------------------------------------------------------------------- /EnvironmentSnow_Keyboard.chroma: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/razerofficial/HTML5ChromaSDK/ec61d7a1924a6facc0e136a84a00b8b87f7ce4ba/EnvironmentSnow_Keyboard.chroma -------------------------------------------------------------------------------- /FadeInOutGray_ChromaLink.chroma: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/razerofficial/HTML5ChromaSDK/ec61d7a1924a6facc0e136a84a00b8b87f7ce4ba/FadeInOutGray_ChromaLink.chroma -------------------------------------------------------------------------------- /FadeInOutGray_Headset.chroma: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/razerofficial/HTML5ChromaSDK/ec61d7a1924a6facc0e136a84a00b8b87f7ce4ba/FadeInOutGray_Headset.chroma -------------------------------------------------------------------------------- /FadeInOutGray_Keyboard.chroma: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/razerofficial/HTML5ChromaSDK/ec61d7a1924a6facc0e136a84a00b8b87f7ce4ba/FadeInOutGray_Keyboard.chroma -------------------------------------------------------------------------------- /FadeInOutGray_Keypad.chroma: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/razerofficial/HTML5ChromaSDK/ec61d7a1924a6facc0e136a84a00b8b87f7ce4ba/FadeInOutGray_Keypad.chroma -------------------------------------------------------------------------------- /FadeInOutGray_Mouse.chroma: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/razerofficial/HTML5ChromaSDK/ec61d7a1924a6facc0e136a84a00b8b87f7ce4ba/FadeInOutGray_Mouse.chroma -------------------------------------------------------------------------------- /FadeInOutGray_Mousepad.chroma: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/razerofficial/HTML5ChromaSDK/ec61d7a1924a6facc0e136a84a00b8b87f7ce4ba/FadeInOutGray_Mousepad.chroma -------------------------------------------------------------------------------- /FireEffect_ChromaLink.chroma: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/razerofficial/HTML5ChromaSDK/ec61d7a1924a6facc0e136a84a00b8b87f7ce4ba/FireEffect_ChromaLink.chroma -------------------------------------------------------------------------------- /FireEffect_Headset.chroma: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/razerofficial/HTML5ChromaSDK/ec61d7a1924a6facc0e136a84a00b8b87f7ce4ba/FireEffect_Headset.chroma -------------------------------------------------------------------------------- /FireEffect_Keyboard.chroma: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/razerofficial/HTML5ChromaSDK/ec61d7a1924a6facc0e136a84a00b8b87f7ce4ba/FireEffect_Keyboard.chroma -------------------------------------------------------------------------------- /FireEffect_Keypad.chroma: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/razerofficial/HTML5ChromaSDK/ec61d7a1924a6facc0e136a84a00b8b87f7ce4ba/FireEffect_Keypad.chroma -------------------------------------------------------------------------------- /FireEffect_Mouse.chroma: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/razerofficial/HTML5ChromaSDK/ec61d7a1924a6facc0e136a84a00b8b87f7ce4ba/FireEffect_Mouse.chroma -------------------------------------------------------------------------------- /FireEffect_Mousepad.chroma: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/razerofficial/HTML5ChromaSDK/ec61d7a1924a6facc0e136a84a00b8b87f7ce4ba/FireEffect_Mousepad.chroma -------------------------------------------------------------------------------- /HeadsetEffects.js: -------------------------------------------------------------------------------- 1 | // JavaScript source code 2 | 3 | function HeadsetEffects() { 4 | this.alertFrames = false; 5 | this.positiveAlert; 6 | this.negativeAlert; 7 | this.noAlert; 8 | 9 | this.damageFrames = false; 10 | this.damageOn; 11 | this.damageOff; 12 | } 13 | 14 | HeadsetEffects.prototype = { 15 | createHealthAmmoMana: function(type, value) { 16 | var data; 17 | if (type == 1) { // Health 18 | var green = (value / 100.0) * 0xff; 19 | var red = 0xff - ((value / 100.0) * 0xff); 20 | var color = (green) << 8 | red; 21 | 22 | for (i = 0; i < 5; i++) { 23 | data = color; 24 | } 25 | } 26 | 27 | chromaSDK.createHeadsetEffect("CHROMA_STATIC", data); 28 | }, 29 | createAlerts: function(type) { 30 | if (this.alertFrames == false) { 31 | this.positiveAlert = chromaSDK.preCreateHeadsetEffect("CHROMA_STATIC", 0xff00); 32 | this.negativeAlert = chromaSDK.preCreateHeadsetEffect("CHROMA_STATIC", 0xff); 33 | this.noAlert = chromaSDK.preCreateHeadsetEffect("CHROMA_NONE"); 34 | this.alertFrames = true; 35 | } 36 | 37 | if (type == 1) { 38 | chromaSDK.setEffect(this.noAlert); 39 | 40 | sleep(200); 41 | 42 | chromaSDK.setEffect(this.positiveAlert); 43 | 44 | sleep(200); 45 | 46 | chromaSDK.setEffect(this.noAlert); 47 | 48 | sleep(200); 49 | 50 | chromaSDK.setEffect(this.positiveAlert); 51 | 52 | sleep(200); 53 | 54 | chromaSDK.setEffect(this.noAlert); 55 | 56 | sleep(200); 57 | 58 | chromaSDK.setEffect(this.positiveAlert); 59 | 60 | sleep(200); 61 | 62 | chromaSDK.setEffect(this.noAlert); 63 | 64 | 65 | } else if (type == 0) { 66 | 67 | chromaSDK.setEffect(this.noAlert); 68 | 69 | sleep(200); 70 | 71 | chromaSDK.setEffect(this.negativeAlert); 72 | 73 | sleep(200); 74 | 75 | chromaSDK.setEffect(this.noAlert); 76 | 77 | sleep(200); 78 | 79 | chromaSDK.setEffect(this.negativeAlert); 80 | 81 | sleep(200); 82 | 83 | chromaSDK.setEffect(this.noAlert); 84 | 85 | sleep(200); 86 | 87 | chromaSDK.setEffect(this.negativeAlert); 88 | 89 | sleep(200); 90 | 91 | chromaSDK.setEffect(this.noAlert); 92 | } 93 | }, 94 | createDamageTaken: function(){ 95 | 96 | if (this.damageFrames == false) { 97 | this.damageOn = chromaSDK.preCreateHeadsetEffect("CHROMA_STATIC", 0xff); 98 | 99 | this.damageOff = chromaSDK.preCreateHeadsetEffect("CHROMA_NONE"); 100 | this.damageFrames = true; 101 | } 102 | 103 | chromaSDK.setEffect(this.damageOn); 104 | 105 | sleep(50); 106 | 107 | chromaSDK.setEffect(this.damageOff); 108 | }, 109 | free: function(){ 110 | if (this.loadingFrames == true) { 111 | chromaSDK.deleteEffect(this.loadingFrame1); 112 | chromaSDK.deleteEffect(this.loadingFrame2); 113 | chromaSDK.deleteEffect(this.loadingFrame3); 114 | chromaSDK.deleteEffect(this.loadingFrame4); 115 | chromaSDK.deleteEffect(this.loadingFrame5); 116 | chromaSDK.deleteEffect(this.loadingFrame6); 117 | chromaSDK.deleteEffect(this.loadingFrame7); 118 | chromaSDK.deleteEffect(this.loadingFrame8); 119 | chromaSDK.deleteEffect(this.loadingFrame9); 120 | chromaSDK.deleteEffect(this.loadingFrame10); 121 | chromaSDK.deleteEffect(this.loadingFrame11); 122 | chromaSDK.deleteEffect(this.loadingFrame12); 123 | this.loadingFrames = false; 124 | } 125 | 126 | if (this.alertFrames == true) { 127 | chromaSDK.deleteEffect(this.positiveAlert); 128 | chromaSDK.deleteEffect(this.negativeAlert); 129 | chromaSDK.deleteEffect(this.noAlert); 130 | this.alertFrames = false; 131 | } 132 | 133 | if (this.damageFrames == true) { 134 | chromaSDK.deleteEffect(this.damageOn); 135 | chromaSDK.deleteEffect(this.damageOff); 136 | this.damageFrames = false; 137 | } 138 | } 139 | } 140 | 141 | -------------------------------------------------------------------------------- /KeyboardEffects.js: -------------------------------------------------------------------------------- 1 | // JavaScript source code 2 | 3 | function KeyboardEffects() { 4 | this.loadingFrames = false; 5 | this.loadingFrame1; 6 | this.loadingFrame2; 7 | this.loadingFrame3; 8 | this.loadingFrame4; 9 | this.loadingFrame5; 10 | this.loadingFrame6; 11 | this.loadingFrame7; 12 | this.loadingFrame8; 13 | 14 | this.alertFrames = false; 15 | this.positiveAlert; 16 | this.negativeAlert; 17 | this.noAlert; 18 | 19 | this.damageFrames = false; 20 | this.damageOn; 21 | this.damageOff; 22 | } 23 | 24 | var timerId = 0; 25 | var blink = 0; 26 | function onKeyboadTimer(keyCode) { 27 | var color = new Array(6); 28 | for (r = 0; r < 6; r++) { 29 | color[r] = new Array(22); 30 | for (c = 0; c < 22; c++) { 31 | color[r][c] = 0; 32 | } 33 | } 34 | 35 | var key = new Array(6); 36 | for (r = 0; r < 6; r++) { 37 | key[r] = new Array(22); 38 | for (c = 0; c < 22; c++) { 39 | key[r][c] = 0; 40 | } 41 | } 42 | 43 | if (blink == 0) { 44 | if (keyCode == '87') { 45 | key[2][3] = 0; 46 | key[3][2] = 0; 47 | key[3][3] = 0; 48 | key[3][4] = 0; 49 | } else if (keyCode == '65') { 50 | key[2][3] = 0x01000000 | 0xffffff; 51 | key[3][2] = 0; 52 | key[3][3] = 0; 53 | key[3][4] = 0; 54 | } else if (keyCode == '83') { 55 | key[2][3] = 0x01000000 | 0xffffff; 56 | key[3][2] = 0x01000000 | 0xffffff; 57 | key[3][3] = 0; 58 | key[3][4] = 0; 59 | } else if (keyCode == '68') { 60 | key[2][3] = 0x01000000 | 0xffffff; 61 | key[3][2] = 0x01000000 | 0xffffff; 62 | key[3][3] = 0x01000000 | 0xffffff; 63 | key[3][4] = 0; 64 | } 65 | blink = 1; 66 | } else if (blink == 1) { 67 | if (keyCode == '87') { 68 | key[2][3] = 0x01000000 | 0xffffff; 69 | } else if (keyCode == '65') { 70 | key[2][3] = 0x01000000 | 0xffffff; 71 | key[3][2] = 0x01000000 | 0xffffff; 72 | } else if (keyCode == '83') { 73 | key[2][3] = 0x01000000 | 0xffffff; 74 | key[3][2] = 0x01000000 | 0xffffff; 75 | key[3][3] = 0x01000000 | 0xffffff; 76 | } else if (keyCode == '68') { 77 | key[2][3] = 0x01000000 | 0xffffff; 78 | key[3][2] = 0x01000000 | 0xffffff; 79 | key[3][3] = 0x01000000 | 0xffffff; 80 | key[3][4] = 0x01000000 | 0xffffff; 81 | } 82 | blink = 0; 83 | } 84 | 85 | var data = { 'color': color, 'key': key }; 86 | 87 | chromaSDK.createKeyboardEffect("CHROMA_CUSTOM_KEY", data); 88 | } 89 | 90 | KeyboardEffects.prototype = { 91 | createLoadingAnimation: function () { 92 | if (this.loadingFrames == false) { 93 | this.loadingFrame1 = chromaSDK.preCreateKeyboardEffect("CHROMA_NONE"); 94 | 95 | var data = new Array(6); 96 | for (r = 0; r < 6; r++) { 97 | data[r] = new Array(22); 98 | 99 | for (c = 0; c < 22; c++) { 100 | if (c < 3) { 101 | data[r][c] = 0x00a5ff; // orange 102 | } else { 103 | data[r][c] = 0; // black 104 | } 105 | } 106 | } 107 | 108 | this.loadingFrame2 = chromaSDK.preCreateKeyboardEffect("CHROMA_CUSTOM", data); 109 | 110 | for (r = 0; r < 6; r++) { 111 | data[r] = new Array(22); 112 | 113 | for (c = 0; c < 22; c++) { 114 | if (c < 6) { 115 | data[r][c] = 0x00a5ff; // orange 116 | } else { 117 | data[r][c] = 0; // black 118 | } 119 | } 120 | } 121 | 122 | this.loadingFrame3 = chromaSDK.preCreateKeyboardEffect("CHROMA_CUSTOM", data); 123 | 124 | for (r = 0; r < 6; r++) { 125 | data[r] = new Array(22); 126 | 127 | for (c = 0; c < 22; c++) { 128 | if (c < 9) { 129 | data[r][c] = 0x00a5ff; // orange 130 | } else { 131 | data[r][c] = 0; // black 132 | } 133 | } 134 | } 135 | 136 | this.loadingFrame4 = chromaSDK.preCreateKeyboardEffect("CHROMA_CUSTOM", data); 137 | 138 | for (r = 0; r < 6; r++) { 139 | data[r] = new Array(22); 140 | 141 | for (c = 0; c < 22; c++) { 142 | if (c < 12) { 143 | data[r][c] = 0x00a5ff; // orange 144 | } else { 145 | data[r][c] = 0; // black 146 | } 147 | } 148 | } 149 | 150 | this.loadingFrame5 = chromaSDK.preCreateKeyboardEffect("CHROMA_CUSTOM", data); 151 | 152 | for (r = 0; r < 6; r++) { 153 | data[r] = new Array(22); 154 | 155 | for (c = 0; c < 22; c++) { 156 | if (c < 15) { 157 | data[r][c] = 0x00a5ff; // orange 158 | } else { 159 | data[r][c] = 0; // black 160 | } 161 | } 162 | } 163 | 164 | this.loadingFrame6 = chromaSDK.preCreateKeyboardEffect("CHROMA_CUSTOM", data); 165 | 166 | for (r = 0; r < 6; r++) { 167 | data[r] = new Array(22); 168 | 169 | for (c = 0; c < 22; c++) { 170 | if (c < 18) { 171 | data[r][c] = 0x00a5ff; // orange 172 | } else { 173 | data[r][c] = 0; // black 174 | } 175 | } 176 | } 177 | 178 | this.loadingFrame7 = chromaSDK.preCreateKeyboardEffect("CHROMA_CUSTOM", data); 179 | 180 | var color = 0x00a5ff; 181 | 182 | this.loadingFrame8 = chromaSDK.preCreateKeyboardEffect("CHROMA_STATIC", color); 183 | 184 | this.loadingFrames = true; 185 | } 186 | 187 | chromaSDK.setEffect(this.loadingFrame1); 188 | 189 | sleep(500); 190 | 191 | chromaSDK.setEffect(this.loadingFrame2); 192 | 193 | sleep(100); 194 | 195 | chromaSDK.setEffect(this.loadingFrame3); 196 | 197 | sleep(100); 198 | 199 | chromaSDK.setEffect(this.loadingFrame4); 200 | 201 | sleep(100); 202 | 203 | chromaSDK.setEffect(this.loadingFrame5); 204 | 205 | sleep(100); 206 | 207 | chromaSDK.setEffect(this.loadingFrame6); 208 | 209 | sleep(100); 210 | 211 | chromaSDK.setEffect(this.loadingFrame7); 212 | 213 | sleep(100); 214 | 215 | chromaSDK.setEffect(this.loadingFrame8); 216 | }, 217 | createTutorial: function (keyCode) { 218 | var color = new Array(6); 219 | for (r = 0; r < 6; r++) { 220 | color[r] = new Array(22); 221 | for (c = 0; c < 22; c++) { 222 | color[r][c] = 0; 223 | } 224 | } 225 | 226 | var key = new Array(6); 227 | for (r = 0; r < 6; r++) { 228 | key[r] = new Array(22); 229 | for (c = 0; c < 22; c++) { 230 | key[r][c] = 0; 231 | } 232 | } 233 | 234 | if (keyCode != '0') { 235 | if (keyCode == '87') { 236 | key[2][3] = 0x01000000 | 0xffffff; 237 | } else if (keyCode == '65') { 238 | key[2][3] = 0x01000000 | 0xffffff; 239 | key[3][2] = 0x01000000 | 0xffffff; 240 | } else if (keyCode == '83') { 241 | key[2][3] = 0x01000000 | 0xffffff; 242 | key[3][2] = 0x01000000 | 0xffffff; 243 | key[3][3] = 0x01000000 | 0xffffff; 244 | } else if (keyCode == '68') { 245 | key[2][3] = 0x01000000 | 0xffffff; 246 | key[3][2] = 0x01000000 | 0xffffff; 247 | key[3][3] = 0x01000000 | 0xffffff; 248 | key[3][4] = 0x01000000 | 0xffffff; 249 | } 250 | 251 | clearInterval(timerId); 252 | timerId = setInterval(onKeyboadTimer, 500, keyCode); 253 | } else { 254 | clearInterval(timerId); 255 | timerId = 0; 256 | 257 | for (r = 0; r < 6; r++) { 258 | for (c = 0; c < 22; c++) { 259 | color[r][c] = 0; 260 | } 261 | } 262 | 263 | for (r = 0; r < 6; r++) { 264 | for (c = 0; c < 22; c++) { 265 | key[r][c] = 0; 266 | } 267 | } 268 | 269 | key[2][3] = 0x01000000 | 0xffffff; 270 | key[3][2] = 0x01000000 | 0xffffff; 271 | key[3][3] = 0x01000000 | 0xffffff; 272 | key[3][4] = 0x01000000 | 0xffffff; 273 | } 274 | 275 | var data = { 'color': color, 'key': key }; 276 | 277 | chromaSDK.createKeyboardEffect("CHROMA_CUSTOM_KEY", data); 278 | }, 279 | createActiveKeys: function () { 280 | var key = new Array(6); 281 | for (r = 0; r < 6; r++) { 282 | key[r] = new Array(22); 283 | for (c = 0; c < 22; c++) { 284 | if ((r == 0) && (c == 1)) { // Esc 285 | key[r][c] = 0x01000000 | 0xff00; 286 | } else if ((r == 2) && (c == 3)) { // W 287 | key[r][c] = 0x01000000 | 0xff00; 288 | } else if ((r == 3) && (c == 2)) { // A 289 | key[r][c] = 0x01000000 | 0xff00; 290 | } else if ((r == 3) && (c == 3)) { // S 291 | key[r][c] = 0x01000000 | 0xff00; 292 | } else if ((r == 3) && (c == 4)) { // D 293 | key[r][c] = 0x01000000 | 0xff00; 294 | } else if ((r == 4) && (c == 1)) { // Left Shift 295 | key[r][c] = 0x01000000 | 0xff00; 296 | } else if ((r == 5) && (c == 1)) { 297 | key[r][c] = 0x01000000 | 0xff00; // Left Ctrl 298 | } else if ((r == 4) && (c == 16)) { // Up arrow 299 | key[r][c] = 0x01000000 | 0xff00; 300 | } else if ((r == 5) && (c == 15)) { // Left Arrow 301 | key[r][c] = 0x01000000 | 0xff00; 302 | } else if ((r == 5) && (c == 16)) { 303 | key[r][c] = 0x01000000 | 0xff00; // Down arrow 304 | } else if ((r == 5) && (c == 17)) { 305 | key[r][c] = 0x01000000 | 0xff00; // Right arrow 306 | } else { 307 | key[r][c] = 0; 308 | } 309 | } 310 | } 311 | 312 | var color = new Array(6); 313 | for (r = 0; r < 6; r++) { 314 | color[r] = new Array(22); 315 | for (c = 0; c < 22; c++) { 316 | if (r == 0) { 317 | color[r][c] = 0xa5ff; 318 | } else { 319 | color[r][c] = 0; 320 | } 321 | } 322 | } 323 | 324 | color[0][20] = 0; 325 | 326 | var frame = { "color": color, "key": key }; 327 | 328 | chromaSDK.createKeyboardEffect("CHROMA_CUSTOM_KEY", frame); 329 | 330 | sleep(50); 331 | 332 | for (c = 0; c < 22; c++) { 333 | if (c != 20) { 334 | color[0][c] = ((0xa5 * 0.3) << 8) | (0xff * 0.3); 335 | color[1][c] = 0xa5ff; 336 | } 337 | } 338 | 339 | chromaSDK.createKeyboardEffect("CHROMA_CUSTOM_KEY", frame); 340 | 341 | sleep(50); 342 | 343 | for (c = 0; c < 22; c++) { 344 | if (c != 20) { 345 | color[0][c] = ((0xa5 * 0.1) << 8) | (0xff * 0.1); 346 | color[1][c] = ((0xa5 * 0.3) << 8) | (0xff * 0.3); 347 | color[2][c] = 0xa5ff; 348 | } 349 | } 350 | 351 | chromaSDK.createKeyboardEffect("CHROMA_CUSTOM_KEY", frame); 352 | 353 | sleep(50); 354 | 355 | for (c = 0; c < 22; c++) { 356 | if (c != 20) { 357 | color[0][c] = 0; 358 | color[1][c] = ((0xa5 * 0.1) << 8) | (0xff * 0.1); 359 | color[2][c] = ((0xa5 * 0.3) << 8) | (0xff * 0.3); 360 | color[3][c] = 0xa5ff; 361 | } 362 | } 363 | 364 | chromaSDK.createKeyboardEffect("CHROMA_CUSTOM_KEY", frame); 365 | 366 | sleep(50); 367 | 368 | for (c = 0; c < 22; c++) { 369 | if (c != 20) { 370 | color[0][c] = 0; 371 | color[1][c] = 0; 372 | color[2][c] = ((0xa5 * 0.1) << 8) | (0xff * 0.1); 373 | color[3][c] = ((0xa5 * 0.3) << 8) | (0xff * 0.3); 374 | color[4][c] = 0xa5ff; 375 | } 376 | } 377 | 378 | chromaSDK.createKeyboardEffect("CHROMA_CUSTOM_KEY", frame); 379 | 380 | sleep(50); 381 | 382 | for (c = 0; c < 22; c++) { 383 | if (c != 20) { 384 | color[0][c] = 0; 385 | color[1][c] = 0; 386 | color[2][c] = 0; 387 | color[3][c] = ((0xa5 * 0.1) << 8) | (0xff * 0.1); 388 | color[4][c] = ((0xa5 * 0.3) << 8) | (0xff * 0.3); 389 | color[5][c] = 0xa5ff; 390 | } 391 | } 392 | 393 | chromaSDK.createKeyboardEffect("CHROMA_CUSTOM_KEY", frame); 394 | 395 | sleep(50); 396 | 397 | for (c = 0; c < 22; c++) { 398 | if (c != 20) { 399 | color[0][c] = 0; 400 | color[1][c] = 0; 401 | color[2][c] = 0; 402 | color[3][c] = 0; 403 | color[4][c] = ((0xa5 * 0.1) << 8) | (0xff * 0.1); 404 | color[5][c] = ((0xa5 * 0.3) << 8) | (0xff * 0.3); 405 | } 406 | } 407 | 408 | color[0][20] = 0xa5ff; 409 | 410 | chromaSDK.createKeyboardEffect("CHROMA_CUSTOM_KEY", frame); 411 | 412 | sleep(50); 413 | 414 | for (c = 0; c < 22; c++) { 415 | if (c != 20) { 416 | color[0][c] = 0; 417 | color[1][c] = 0; 418 | color[2][c] = 0; 419 | color[3][c] = 0; 420 | color[4][c] = 0; 421 | color[5][c] = ((0xa5 * 0.1) << 8) | (0xff * 0.1); 422 | } 423 | } 424 | 425 | color[0][20] = ((0xa5 * 0.3) << 8) | (0xff * 0.3); 426 | 427 | chromaSDK.createKeyboardEffect("CHROMA_CUSTOM_KEY", frame); 428 | 429 | sleep(50); 430 | 431 | for (c = 0; c < 22; c++) { 432 | if (c != 20) { 433 | color[0][c] = 0; 434 | color[1][c] = 0; 435 | color[2][c] = 0; 436 | color[3][c] = 0; 437 | color[4][c] = 0; 438 | color[5][c] = 0; 439 | } 440 | } 441 | 442 | color[0][20] = ((0xa5 * 0.1) << 8) | (0xff * 0.1); 443 | 444 | chromaSDK.createKeyboardEffect("CHROMA_CUSTOM_KEY", frame); 445 | 446 | sleep(50); 447 | 448 | color[0][20] = 0; 449 | 450 | chromaSDK.createKeyboardEffect("CHROMA_CUSTOM_KEY", frame); 451 | }, 452 | createHealthAmmoMana: function (type, value) { 453 | var key = new Array(6); 454 | for (r = 0; r < 6; r++) { 455 | key[r] = new Array(22); 456 | for (c = 0; c < 22; c++) { 457 | key[r][c] = 0; 458 | } 459 | } 460 | 461 | if (type == 1) { 462 | for (c = 3; c < (3 + (12 * (value / 100.0))) ; c++) { 463 | var green = (value / 100.0) * 0xff; 464 | var red = 0xff - ((value / 100.0) * 0xff); 465 | var color = (green) << 8 | red; 466 | 467 | key[0][c] = 0x01000000 | color; 468 | } 469 | } else if (type == 2) { 470 | for (c = 2; c < (2 + (10 * (value / 100.0))) ; c++) { 471 | key[1][c] = 0x01000000 | 0xffff; 472 | } 473 | } 474 | 475 | var color = new Array(6); 476 | for (r = 0; r < 6; r++) { 477 | color[r] = new Array(22); 478 | for (c = 0; c < 22; c++) { 479 | color[r][c] = 0; 480 | } 481 | } 482 | 483 | var data = { "color": color, "key": key }; 484 | 485 | chromaSDK.createKeyboardEffect("CHROMA_CUSTOM_KEY", data); 486 | }, 487 | createAlerts: function (type) { 488 | 489 | if (this.alertFrames == false) { 490 | this.positiveAlert = chromaSDK.preCreateKeyboardEffect("CHROMA_STATIC", 0xff00); 491 | this.negativeAlert = chromaSDK.preCreateKeyboardEffect("CHROMA_STATIC", 0xff); 492 | this.noAlert = chromaSDK.preCreateKeyboardEffect("CHROMA_NONE"); 493 | this.alertFrames = true; 494 | } 495 | 496 | if (type == 1) { 497 | chromaSDK.setEffect(this.noAlert); 498 | 499 | sleep(200); 500 | 501 | chromaSDK.setEffect(this.positiveAlert); 502 | 503 | sleep(200); 504 | 505 | chromaSDK.setEffect(this.noAlert); 506 | 507 | sleep(200); 508 | 509 | chromaSDK.setEffect(this.positiveAlert); 510 | 511 | sleep(200); 512 | 513 | chromaSDK.setEffect(this.noAlert); 514 | 515 | sleep(200); 516 | 517 | chromaSDK.setEffect(this.positiveAlert); 518 | 519 | sleep(200); 520 | 521 | chromaSDK.setEffect(this.noAlert); 522 | 523 | 524 | } else if (type == 0) { 525 | 526 | chromaSDK.setEffect(this.noAlert); 527 | 528 | sleep(200); 529 | 530 | chromaSDK.setEffect(this.negativeAlert); 531 | 532 | sleep(200); 533 | 534 | chromaSDK.setEffect(this.noAlert); 535 | 536 | sleep(200); 537 | 538 | chromaSDK.setEffect(this.negativeAlert); 539 | 540 | sleep(200); 541 | 542 | chromaSDK.setEffect(this.noAlert); 543 | 544 | sleep(200); 545 | 546 | chromaSDK.setEffect(this.negativeAlert); 547 | 548 | sleep(200); 549 | 550 | chromaSDK.setEffect(this.noAlert); 551 | } 552 | }, 553 | createCooldownTimer: function (value) { 554 | var steps = Math.ceil(18 * (value / 100.0)); 555 | 556 | var rowIndex = [2, 2, 3, 4, 4, 4, 3, 2, 3, 2, 2, 3, 4, 4, 4, 3, 2, 3]; 557 | var colIndex = [19, 20, 20, 20, 19, 18, 18, 18, 19, 19, 20, 20, 20, 19, 18, 18, 18, 19]; 558 | var colors = [0x017d7d7d, 0x017d7d7d, 0x017d7d7d, 0x017d7d7d, 0x017d7d7d, 0x017d7d7d, 0x017d7d7d, 0x017d7d7d, 0x017d7d7d, 0x0100ffff, 0x0100ffff, 0x0100ffff, 0x0100ffff, 0x0100ffff, 0x0100ffff, 0x0100ffff, 0x0100ffff, 0x0100ffff] 559 | 560 | var key = new Array(6); 561 | for (r = 0; r < 6; r++) { 562 | key[r] = new Array(22); 563 | for (c = 0; c < 22; c++) { 564 | key[r][c] = 0; 565 | } 566 | } 567 | 568 | for (i = 0; i < steps; i++) { 569 | key[rowIndex[i]][colIndex[i]] = colors[i]; 570 | } 571 | 572 | var color = new Array(6); 573 | for (r = 0; r < 6; r++) { 574 | color[r] = new Array(22); 575 | for (c = 0; c < 22; c++) { 576 | color[r][c] = 0; 577 | } 578 | } 579 | 580 | var data = { "color": color, "key": key }; 581 | 582 | chromaSDK.createKeyboardEffect("CHROMA_CUSTOM_KEY", data); 583 | }, 584 | createDamagaTaken: function () { 585 | 586 | if (this.damageFrames == false) { 587 | this.damageOn = chromaSDK.preCreateKeyboardEffect("CHROMA_STATIC", 0xff); 588 | 589 | this.damageOff = chromaSDK.preCreateKeyboardEffect("CHROMA_NONE"); 590 | this.damageFrames = true; 591 | } 592 | 593 | chromaSDK.setEffect(this.damageOn); 594 | 595 | sleep(50); 596 | 597 | chromaSDK.setEffect(this.damageOff); 598 | }, 599 | free: function () { 600 | if (this.loadingFrames == true) { 601 | 602 | var effectIds = JSON.stringify({ 603 | "id": [ 604 | this.loadingFrame1, 605 | this.loadingFrame2, 606 | this.loadingFrame3, 607 | this.loadingFrame4, 608 | this.loadingFrame5, 609 | this.loadingFrame6, 610 | this.loadingFrame7, 611 | this.loadingFrame8 612 | ] 613 | }); 614 | chromaSDK.deleteEffectGroup(effectIds); 615 | 616 | //chromaSDK.deleteEffect(this.loadingFrame1); 617 | //chromaSDK.deleteEffect(this.loadingFrame2); 618 | //chromaSDK.deleteEffect(this.loadingFrame3); 619 | //chromaSDK.deleteEffect(this.loadingFrame4); 620 | //chromaSDK.deleteEffect(this.loadingFrame5); 621 | //chromaSDK.deleteEffect(this.loadingFrame6); 622 | //chromaSDK.deleteEffect(this.loadingFrame7); 623 | //chromaSDK.deleteEffect(this.loadingFrame8); 624 | this.loadingFrames = false; 625 | } 626 | 627 | if (this.alertFrames == true) { 628 | chromaSDK.deleteEffect(this.positiveAlert); 629 | chromaSDK.deleteEffect(this.negativeAlert); 630 | chromaSDK.deleteEffect(this.noAlert); 631 | this.alertFrames = false; 632 | } 633 | 634 | if (this.damageFrames == true) { 635 | chromaSDK.deleteEffect(this.damageOn); 636 | chromaSDK.deleteEffect(this.damageOff); 637 | this.damageFrames = false; 638 | } 639 | } 640 | } 641 | -------------------------------------------------------------------------------- /KeypadEffects.js: -------------------------------------------------------------------------------- 1 | // JavaScript source code 2 | function KeypadEffects () { 3 | this.loadingFrames = false; 4 | this.loadingFrame1; 5 | this.loadingFrame2; 6 | this.loadingFrame3; 7 | this.loadingFrame4; 8 | this.loadingFrame5; 9 | this.loadingFrame6; 10 | 11 | this.alertFrames = false; 12 | this.positiveAlert; 13 | this.negativeAlert; 14 | this.noAlert; 15 | 16 | this.damageFrames = false; 17 | this.damageOn; 18 | this.damageOff; 19 | } 20 | 21 | var timerId; 22 | var blink = 0; 23 | function onKeypadTimer(keyCode) { 24 | var color = new Array(4); 25 | for (r = 0; r < 4; r++) { 26 | color[r] = new Array(5); 27 | for (c = 0; c < 5; c++) { 28 | color[r][c] = 0; 29 | } 30 | } 31 | 32 | if (blink == 0) { 33 | if (keyCode == '87') { 34 | color[1][2] = 0; 35 | color[2][1] = 0; 36 | color[2][2] = 0; 37 | color[2][3] = 0; 38 | } else if (keyCode == '65') { 39 | color[1][2] = 0xffffff; 40 | color[2][1] = 0; 41 | color[2][2] = 0; 42 | color[2][3] = 0; 43 | } else if (keyCode == '83') { 44 | color[1][2] = 0xffffff; 45 | color[2][1] = 0xffffff; 46 | color[2][2] = 0; 47 | color[2][3] = 0; 48 | } else if (keyCode == '68') { 49 | color[1][2] = 0xffffff; 50 | color[2][1] = 0xffffff; 51 | color[2][2] = 0xffffff; 52 | color[2][3] = 0; 53 | } 54 | blink = 1; 55 | } else if (blink == 1) { 56 | if (keyCode == '87') { 57 | color[1][2] = 0x01000000 | 0xffffff; 58 | } else if (keyCode == '65') { 59 | color[1][2] = 0x01000000 | 0xffffff; 60 | color[2][1] = 0x01000000 | 0xffffff; 61 | } else if (keyCode == '83') { 62 | color[1][2] = 0x01000000 | 0xffffff; 63 | color[2][1] = 0x01000000 | 0xffffff; 64 | color[2][2] = 0x01000000 | 0xffffff; 65 | } else if (keyCode == '68') { 66 | color[1][2] = 0x01000000 | 0xffffff; 67 | color[2][1] = 0x01000000 | 0xffffff; 68 | color[2][2] = 0x01000000 | 0xffffff; 69 | color[2][3] = 0x01000000 | 0xffffff; 70 | } 71 | blink = 0; 72 | } 73 | 74 | chromaSDK.createKeypadEffect("CHROMA_CUSTOM", color); 75 | } 76 | 77 | KeypadEffects.prototype = { 78 | createLoadingAnimation: function () { 79 | var data = new Array(4); 80 | for (r = 0; r < 4; r++) { 81 | data[r] = new Array(5); 82 | 83 | for (c = 0; c < 5; c++) { 84 | data[r][c] = 0; 85 | } 86 | } 87 | 88 | chromaSDK.createKeypadEffect("CHROMA_NONE"); 89 | 90 | sleep(500); 91 | 92 | for (c = 0; c < 5; c++) { 93 | 94 | for (r = 0; r < 4; r++) { 95 | data[r][c] = 0xa5ff; 96 | } 97 | 98 | sleep(100); 99 | 100 | chromaSDK.createKeypadEffect("CHROMA_CUSTOM", data); 101 | } 102 | }, 103 | createTutorial: function (keyCode) { 104 | var color = new Array(4); 105 | for (r = 0; r < 4; r++) { 106 | color[r] = new Array(5); 107 | for (c = 0; c < 5; c++) { 108 | color[r][c] = 0; 109 | } 110 | } 111 | 112 | if (keyCode != '0') { 113 | 114 | if (keyCode == '87') { 115 | color[1][2] = 0xffffff; 116 | } else if (keyCode == '65') { 117 | color[1][2] = 0xffffff; 118 | color[2][1] = 0xffffff; 119 | } else if (keyCode == '83') { 120 | color[1][2] = 0xffffff; 121 | color[2][1] = 0xffffff; 122 | color[2][2] = 0xffffff; 123 | } else if (keyCode == '68') { 124 | color[1][2] = 0xffffff; 125 | color[2][1] = 0xffffff; 126 | color[2][2] = 0xffffff; 127 | color[2][3] = 0xffffff; 128 | } 129 | 130 | clearInterval(timerId); 131 | timerId = setInterval(onKeypadTimer, 500, keyCode); 132 | } else { 133 | clearInterval(timerId); 134 | timerId = 0; 135 | 136 | var color = new Array(4); 137 | for (r = 0; r < 4; r++) { 138 | color[r] = new Array(5); 139 | for (c = 0; c < 5; c++) { 140 | color[r][c] = 0; 141 | } 142 | } 143 | 144 | color[1][2] = 0xffffff; 145 | color[2][1] = 0xffffff; 146 | color[2][2] = 0xffffff; 147 | color[2][3] = 0xffffff; 148 | } 149 | 150 | chromaSDK.createKeypadEffect("CHROMA_CUSTOM", color); 151 | }, 152 | createActiveKeys: function() { 153 | var color = new Array(4); 154 | for (r = 0; r < 4; r++) { 155 | color[r] = new Array(5); 156 | for (c = 0; c < 5; c++) { 157 | color[r][c] = 0; 158 | } 159 | } 160 | 161 | color[1][2] = 0xff00; 162 | color[2][1] = 0xff00; 163 | color[2][2] = 0xff00; 164 | color[2][3] = 0xff00; 165 | 166 | chromaSDK.createKeypadEffect("CHROMA_CUSTOM", color); 167 | 168 | sleep(50); 169 | 170 | for (c = 0; c < 5; c++) { 171 | color[0][c] = 0xa5ff; 172 | } 173 | 174 | color[1][2] = 0xff00; 175 | color[2][1] = 0xff00; 176 | color[2][2] = 0xff00; 177 | color[2][3] = 0xff00; 178 | 179 | chromaSDK.createKeypadEffect("CHROMA_CUSTOM", color); 180 | 181 | sleep(50); 182 | 183 | for (c = 0; c < 5; c++) { 184 | color[0][c] = ((0xa5 * 0.3) << 8) | (0xff * 0.3); 185 | color[1][c] = 0xa5ff; 186 | } 187 | 188 | color[1][2] = 0xff00; 189 | color[2][1] = 0xff00; 190 | color[2][2] = 0xff00; 191 | color[2][3] = 0xff00; 192 | 193 | chromaSDK.createKeypadEffect("CHROMA_CUSTOM", color); 194 | 195 | sleep(50); 196 | 197 | for (c = 0; c < 5; c++) { 198 | color[0][c] = ((0xa5 * 0.1) << 8) | (0xff * 0.1); 199 | color[1][c] = ((0xa5 * 0.3) << 8) | (0xff * 0.3); 200 | color[2][c] = 0xa5ff; 201 | } 202 | 203 | color[1][2] = 0xff00; 204 | color[2][1] = 0xff00; 205 | color[2][2] = 0xff00; 206 | color[2][3] = 0xff00; 207 | 208 | chromaSDK.createKeypadEffect("CHROMA_CUSTOM", color); 209 | 210 | sleep(50); 211 | 212 | for (c = 0; c < 5; c++) { 213 | color[0][c] = 0; 214 | color[1][c] = ((0xa5 * 0.1) << 8) | (0xff * 0.1); 215 | color[2][c] = ((0xa5 * 0.3) << 8) | (0xff * 0.3); 216 | color[3][c] = 0xa5ff; 217 | } 218 | 219 | color[1][2] = 0xff00; 220 | color[2][1] = 0xff00; 221 | color[2][2] = 0xff00; 222 | color[2][3] = 0xff00; 223 | 224 | chromaSDK.createKeypadEffect("CHROMA_CUSTOM", color); 225 | 226 | sleep(50); 227 | 228 | for (c = 0; c < 5; c++) { 229 | color[0][c] = 0; 230 | color[1][c] = 0; 231 | color[2][c] = ((0xa5 * 0.1) << 8) | (0xff * 0.1); 232 | color[3][c] = ((0xa5 * 0.3) << 8) | (0xff * 0.3); 233 | } 234 | 235 | color[1][2] = 0xff00; 236 | color[2][1] = 0xff00; 237 | color[2][2] = 0xff00; 238 | color[2][3] = 0xff00; 239 | 240 | chromaSDK.createKeypadEffect("CHROMA_CUSTOM", color); 241 | 242 | sleep(50); 243 | 244 | for (c = 0; c < 5; c++) { 245 | color[0][c] = 0; 246 | color[1][c] = 0; 247 | color[2][c] = 0; 248 | color[3][c] = ((0xa5 * 0.1) << 8) | (0xff * 0.1); 249 | } 250 | 251 | color[1][2] = 0xff00; 252 | color[2][1] = 0xff00; 253 | color[2][2] = 0xff00; 254 | color[2][3] = 0xff00; 255 | 256 | chromaSDK.createKeypadEffect("CHROMA_CUSTOM", color); 257 | 258 | sleep(50); 259 | 260 | for (c = 0; c < 5; c++) { 261 | color[0][c] = 0; 262 | color[1][c] = 0; 263 | color[2][c] = 0; 264 | color[3][c] = 0; 265 | } 266 | 267 | color[1][2] = 0xff00; 268 | color[2][1] = 0xff00; 269 | color[2][2] = 0xff00; 270 | color[2][3] = 0xff00; 271 | 272 | chromaSDK.createKeypadEffect("CHROMA_CUSTOM", color); 273 | }, 274 | createHealthAmmoMana: function(type, value) { 275 | var data = new Array(4); 276 | for (r = 0; r < 4; r++) { 277 | data[r] = new Array(5); 278 | for (c = 0; c < 5; c++) { 279 | data[r][c] = 0; 280 | } 281 | } 282 | 283 | if (type == 1) { 284 | for (c = 0; c < (5 * (value / 100.0)) ; c++) { 285 | var green = (value / 100.0) * 0xff; 286 | var red = 0xff - ((value / 100.0) * 0xff); 287 | var color = (green) << 8 | red; 288 | 289 | data[0][c] = color; 290 | } 291 | } else if (type == 2) { 292 | for (c = 0; c < (5 * (value / 100.0)) ; c++) { 293 | data[3][c] = 0xffff; 294 | } 295 | } 296 | 297 | chromaSDK.createKeypadEffect("CHROMA_CUSTOM", data); 298 | }, 299 | createAlerts: function(type) { 300 | 301 | if (this.alertFrames == false) { 302 | this.positiveAlert = chromaSDK.preCreateKeypadEffect("CHROMA_STATIC", 0xff00); 303 | this.negativeAlert = chromaSDK.preCreateKeypadEffect("CHROMA_STATIC", 0xff); 304 | this.noAlert = chromaSDK.preCreateKeypadEffect("CHROMA_NONE"); 305 | this.alertFrames = true; 306 | } 307 | 308 | if (type == 1) { 309 | chromaSDK.setEffect(this.noAlert); 310 | 311 | sleep(200); 312 | 313 | chromaSDK.setEffect(this.positiveAlert); 314 | 315 | sleep(200); 316 | 317 | chromaSDK.setEffect(this.noAlert); 318 | 319 | sleep(200); 320 | 321 | chromaSDK.setEffect(this.positiveAlert); 322 | 323 | sleep(200); 324 | 325 | chromaSDK.setEffect(this.noAlert); 326 | 327 | sleep(200); 328 | 329 | chromaSDK.setEffect(this.positiveAlert); 330 | 331 | sleep(200); 332 | 333 | chromaSDK.setEffect(this.noAlert); 334 | 335 | 336 | } else if (type == 0) { 337 | 338 | chromaSDK.setEffect(this.noAlert); 339 | 340 | sleep(200); 341 | 342 | chromaSDK.setEffect(this.negativeAlert); 343 | 344 | sleep(200); 345 | 346 | chromaSDK.setEffect(this.noAlert); 347 | 348 | sleep(200); 349 | 350 | chromaSDK.setEffect(this.negativeAlert); 351 | 352 | sleep(200); 353 | 354 | chromaSDK.setEffect(this.noAlert); 355 | 356 | sleep(200); 357 | 358 | chromaSDK.setEffect(this.negativeAlert); 359 | 360 | sleep(200); 361 | 362 | chromaSDK.setEffect(this.noAlert); 363 | } 364 | }, 365 | createCooldownTimer: function(value) { 366 | var steps = Math.ceil(14 * (value / 100.0)); 367 | 368 | var rowIndex = [0, 0, 0, 0, 0, 1, 2, 3, 3, 3, 3, 3, 2, 1]; 369 | var colIndex = [0, 1, 2, 3, 4, 4, 4, 4, 3, 2, 1, 0, 0, 0]; 370 | 371 | var color= new Array(4); 372 | for (r = 0; r < 4; r++) { 373 | color[r] = new Array(5); 374 | for (c = 0; c < 5; c++) { 375 | color[r][c] = 0; 376 | } 377 | } 378 | 379 | for (i = 0; i < steps; i++) { 380 | color[rowIndex[i]][colIndex[i]] = 0xffff; 381 | } 382 | 383 | chromaSDK.createKeypadEffect("CHROMA_CUSTOM", color); 384 | }, 385 | createDamagaTaken: function() { 386 | if (this.damageFrames == false) { 387 | this.damageOn = chromaSDK.preCreateKeypadEffect("CHROMA_STATIC", 0xff); 388 | 389 | this.damageOff = chromaSDK.preCreateKeypadEffect("CHROMA_NONE"); 390 | this.damageFrames = true; 391 | } 392 | 393 | chromaSDK.setEffect(this.damageOn); 394 | 395 | sleep(50); 396 | 397 | chromaSDK.setEffect(this.damageOff); 398 | }, 399 | free: function(){ 400 | if (this.loadingFrames == true) { 401 | chromaSDK.deleteEffect(this.loadingFrame1); 402 | chromaSDK.deleteEffect(this.loadingFrame2); 403 | chromaSDK.deleteEffect(this.loadingFrame3); 404 | chromaSDK.deleteEffect(this.loadingFrame4); 405 | chromaSDK.deleteEffect(this.loadingFrame5); 406 | chromaSDK.deleteEffect(this.loadingFrame6); 407 | this.loadingFrames = false; 408 | } 409 | 410 | if (this.alertFrames == true) { 411 | chromaSDK.deleteEffect(this.positiveAlert); 412 | chromaSDK.deleteEffect(this.negativeAlert); 413 | chromaSDK.deleteEffect(this.noAlert); 414 | this.alertFrames = false; 415 | } 416 | 417 | if (this.damageFrames == true) { 418 | chromaSDK.deleteEffect(this.damageOn); 419 | chromaSDK.deleteEffect(this.damageOff); 420 | this.damageFrames = false; 421 | } 422 | } 423 | } -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | MIT License 2 | 3 | Copyright (c) 2019 Razer, Inc. 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining a copy 6 | of this software and associated documentation files (the "Software"), to deal 7 | in the Software without restriction, including without limitation the rights 8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 9 | copies of the Software, and to permit persons to whom the Software is 10 | furnished to do so, subject to the following conditions: 11 | 12 | The above copyright notice and this permission notice shall be included in all 13 | copies or substantial portions of the Software. 14 | 15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 21 | SOFTWARE. 22 | -------------------------------------------------------------------------------- /LayerSample.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 26 | 27 | 323 | 324 | 325 | 326 | 327 |
328 |
329 | 330 | Base Intensity: 331 | 332 |
100%
333 |
334 | 335 | Effect Intensity: 336 | 337 |
100%
338 |
339 | 340 | Hotkey Intensity: 341 | 342 |
100%
343 |
344 | 345 | 348 | 349 | 350 | 351 | -------------------------------------------------------------------------------- /ModalDlg.css: -------------------------------------------------------------------------------- 1 | /* The Modal (background) */ 2 | .modal { 3 | display: none; /* Hidden by default */ 4 | position: fixed; /* Stay in place */ 5 | z-index: 1; /* Sit on top */ 6 | padding-top: 100px; /* Location of the box */ 7 | left: 0; 8 | top: 0; 9 | width: 100%; /* Full width */ 10 | height: 100%; /* Full height */ 11 | overflow: auto; /* Enable scroll if needed */ 12 | background-color: rgb(0,0,0); /* Fallback color */ 13 | background-color: rgba(0,0,0,0.4); /* Black w/ opacity */ 14 | } 15 | 16 | /* Modal Content */ 17 | .modal-content { 18 | background-color: #fefefe; 19 | margin: auto; 20 | padding: 20px; 21 | border: 1px solid #888; 22 | width: 30%; 23 | text-align: center; 24 | min-width: 300px; 25 | } 26 | 27 | /* The Close Button */ 28 | .close { 29 | color: #aaaaaa; 30 | float: right; 31 | font-size: 28px; 32 | font-weight: bold; 33 | } 34 | 35 | .close:hover, 36 | .close:focus { 37 | color: #000; 38 | text-decoration: none; 39 | cursor: pointer; 40 | } 41 | -------------------------------------------------------------------------------- /MouseEffects.js: -------------------------------------------------------------------------------- 1 | // JavaScript source code 2 | 3 | function MouseEffects() { 4 | this.loadingFrames = false; 5 | this.loadingFrame1; 6 | this.loadingFrame2; 7 | this.loadingFrame3; 8 | this.loadingFrame4; 9 | this.loadingFrame5; 10 | this.loadingFrame6; 11 | this.loadingFrame7; 12 | this.loadingFrame8; 13 | this.loadingFrame9; 14 | this.loadingFrame10; 15 | 16 | this.alertFrames = false; 17 | this.positiveAlert; 18 | this.negativeAlert; 19 | this.noAlert; 20 | 21 | this.damageFrames = false; 22 | this.damageOn; 23 | this.damageOff; 24 | } 25 | 26 | MouseEffects.prototype = { 27 | createLoadingAnimation: function () { 28 | if (this.loadingFrames == false) { 29 | this.loadingFrame1 = chromaSDK.preCreateMouseEffect("CHROMA_NONE"); 30 | 31 | var data = new Array(9); 32 | for (r = 0; r < 9; r++) { 33 | data[r] = new Array(7); 34 | for (c = 0; c < 7; c++) { 35 | data[r][c] = 0; 36 | } 37 | } 38 | 39 | for (c = 0; c < 7; c++) { 40 | data[8][c] = 0xa5ff; 41 | } 42 | 43 | this.loadingFrame2 = chromaSDK.preCreateMouseEffect("CHROMA_CUSTOM2", data); 44 | 45 | for (c = 0; c < 7; c++) { 46 | data[7][c] = 0xa5ff; 47 | } 48 | 49 | this.loadingFrame3 = chromaSDK.preCreateMouseEffect("CHROMA_CUSTOM2", data); 50 | 51 | for (c = 0; c < 7; c++) { 52 | data[6][c] = 0xa5ff; 53 | } 54 | 55 | this.loadingFrame4 = chromaSDK.preCreateMouseEffect("CHROMA_CUSTOM2", data); 56 | 57 | for (c = 0; c < 7; c++) { 58 | data[5][c] = 0xa5ff; 59 | } 60 | 61 | this.loadingFrame5 = chromaSDK.preCreateMouseEffect("CHROMA_CUSTOM2", data); 62 | 63 | for (c = 0; c < 7; c++) { 64 | data[4][c] = 0xa5ff; 65 | } 66 | 67 | this.loadingFrame6 = chromaSDK.preCreateMouseEffect("CHROMA_CUSTOM2", data); 68 | 69 | for (c = 0; c < 7; c++) { 70 | data[3][c] = 0xa5ff; 71 | } 72 | 73 | this.loadingFrame7 = chromaSDK.preCreateMouseEffect("CHROMA_CUSTOM2", data); 74 | 75 | for (c = 0; c < 7; c++) { 76 | data[2][c] = 0xa5ff; 77 | } 78 | 79 | this.loadingFrame8 = chromaSDK.preCreateMouseEffect("CHROMA_CUSTOM2", data); 80 | 81 | for (c = 0; c < 7; c++) { 82 | data[1][c] = 0xa5ff; 83 | } 84 | 85 | this.loadingFrame9 = chromaSDK.preCreateMouseEffect("CHROMA_CUSTOM2", data); 86 | 87 | this.loadingFrame10 = chromaSDK.preCreateMouseEffect("CHROMA_STATIC", 0xa5ff); 88 | 89 | this.loadingFrames = true; 90 | } 91 | 92 | chromaSDK.setEffect(this.loadingFrame1); 93 | 94 | sleep(500); 95 | 96 | chromaSDK.setEffect(this.loadingFrame2); 97 | 98 | sleep(100); 99 | 100 | chromaSDK.setEffect(this.loadingFrame3); 101 | 102 | sleep(100); 103 | 104 | chromaSDK.setEffect(this.loadingFrame4); 105 | 106 | sleep(100); 107 | 108 | chromaSDK.setEffect(this.loadingFrame5); 109 | 110 | sleep(100); 111 | 112 | chromaSDK.setEffect(this.loadingFrame6); 113 | 114 | sleep(100); 115 | 116 | chromaSDK.setEffect(this.loadingFrame7); 117 | 118 | sleep(100); 119 | 120 | chromaSDK.setEffect(this.loadingFrame8); 121 | 122 | sleep(100); 123 | 124 | chromaSDK.setEffect(this.loadingFrame9); 125 | 126 | sleep(100); 127 | 128 | chromaSDK.setEffect(this.loadingFrame10); 129 | }, 130 | createHealthAmmoMana: function(type, value){ 131 | var steps = Math.ceil(value / 100.0 * 7); 132 | 133 | var data = new Array(9); 134 | for (r = 0; r < 9; r++) { 135 | data[r] = new Array(7); 136 | for (c = 0; c < 7; c++) { 137 | data[r][c] = 0; 138 | } 139 | } 140 | 141 | var healthRowIndex = [7, 6, 5, 4, 3, 2, 1]; 142 | var healthColIndex = [0, 0, 0, 0, 0, 0, 0]; 143 | var ammoRowIndex = [7, 6, 5, 4, 3, 2, 1]; 144 | var ammoColIndex = [6, 6, 6, 6, 6, 6]; 145 | 146 | if (type == 1) { // Health 147 | var green = (value / 100.0) * 0xff; 148 | var red = 0xff - ((value / 100.0) * 0xff); 149 | var color = (green) << 8 | red; 150 | 151 | for (i = 0; i < steps; i++) { 152 | data[healthRowIndex[i]][healthColIndex[i]] = color; 153 | } 154 | } else if (type == 2) { // Ammo 155 | for (i = 0; i < steps; i++) { 156 | data[ammoRowIndex[i]][ammoColIndex[i]] = 0xffff; 157 | } 158 | } 159 | 160 | chromaSDK.createMouseEffect("CHROMA_CUSTOM2", data); 161 | }, 162 | createAlerts: function (type) { 163 | 164 | if (this.alertFrames == false) { 165 | this.positiveAlert = chromaSDK.preCreateMouseEffect("CHROMA_STATIC", 0xff00); 166 | this.negativeAlert = chromaSDK.preCreateMouseEffect("CHROMA_STATIC", 0xff); 167 | this.noAlert = chromaSDK.preCreateMouseEffect("CHROMA_NONE"); 168 | this.alertFrames = true; 169 | } 170 | 171 | if (type == 1) { 172 | chromaSDK.setEffect(this.noAlert); 173 | 174 | sleep(200); 175 | 176 | chromaSDK.setEffect(this.positiveAlert); 177 | 178 | sleep(200); 179 | 180 | chromaSDK.setEffect(this.noAlert); 181 | 182 | sleep(200); 183 | 184 | chromaSDK.setEffect(this.positiveAlert); 185 | 186 | sleep(200); 187 | 188 | chromaSDK.setEffect(this.noAlert); 189 | 190 | sleep(200); 191 | 192 | chromaSDK.setEffect(this.positiveAlert); 193 | 194 | sleep(200); 195 | 196 | chromaSDK.setEffect(this.noAlert); 197 | 198 | 199 | } else if (type == 0) { 200 | 201 | chromaSDK.setEffect(this.noAlert); 202 | 203 | sleep(200); 204 | 205 | chromaSDK.setEffect(this.negativeAlert); 206 | 207 | sleep(200); 208 | 209 | chromaSDK.setEffect(this.noAlert); 210 | 211 | sleep(200); 212 | 213 | chromaSDK.setEffect(this.negativeAlert); 214 | 215 | sleep(200); 216 | 217 | chromaSDK.setEffect(this.noAlert); 218 | 219 | sleep(200); 220 | 221 | chromaSDK.setEffect(this.negativeAlert); 222 | 223 | sleep(200); 224 | 225 | chromaSDK.setEffect(this.noAlert); 226 | } 227 | }, 228 | createDamageTaken: function() { 229 | if (this.damageFrames == false) { 230 | this.damageOn = chromaSDK.preCreateMouseEffect("CHROMA_STATIC", 0xff); 231 | 232 | this.damageOff = chromaSDK.preCreateMouseEffect("CHROMA_NONE"); 233 | this.damageFrames = true; 234 | } 235 | 236 | chromaSDK.setEffect(this.damageOn); 237 | 238 | sleep(50); 239 | 240 | chromaSDK.setEffect(this.damageOff); 241 | }, 242 | free: function () { 243 | if (this.loadingFrames == true) { 244 | chromaSDK.deleteEffect(this.loadingFrame1); 245 | chromaSDK.deleteEffect(this.loadingFrame2); 246 | chromaSDK.deleteEffect(this.loadingFrame3); 247 | chromaSDK.deleteEffect(this.loadingFrame4); 248 | chromaSDK.deleteEffect(this.loadingFrame5); 249 | chromaSDK.deleteEffect(this.loadingFrame6); 250 | chromaSDK.deleteEffect(this.loadingFrame7); 251 | chromaSDK.deleteEffect(this.loadingFrame8); 252 | chromaSDK.deleteEffect(this.loadingFrame9); 253 | chromaSDK.deleteEffect(this.loadingFrame10); 254 | this.loadingFrames = false; 255 | } 256 | 257 | if (this.alertFrames == true) { 258 | chromaSDK.deleteEffect(this.positiveAlert); 259 | chromaSDK.deleteEffect(this.negativeAlert); 260 | chromaSDK.deleteEffect(this.noAlert); 261 | this.alertFrames = false; 262 | } 263 | 264 | if (this.damageFrames == true) { 265 | chromaSDK.deleteEffect(this.damageOn); 266 | chromaSDK.deleteEffect(this.damageOff); 267 | this.damageFrames = false; 268 | } 269 | } 270 | } 271 | -------------------------------------------------------------------------------- /MousematEffects.js: -------------------------------------------------------------------------------- 1 | // JavaScript source code 2 | 3 | function MousematEffects() { 4 | this.loadingFrames = false; 5 | this.loadingFrame1; 6 | this.loadingFrame2; 7 | this.loadingFrame3; 8 | this.loadingFrame4; 9 | this.loadingFrame5; 10 | this.loadingFrame6; 11 | this.loadingFrame7; 12 | this.loadingFrame8; 13 | this.loadingFrame9; 14 | this.loadingFrame10; 15 | this.loadingFrame11; 16 | this.loadingFrame12; 17 | 18 | this.alertFrames = false; 19 | this.positiveAlert; 20 | this.negativeAlert; 21 | this.noAlert; 22 | 23 | this.damageFrames = false; 24 | this.damageOn; 25 | this.damageOff; 26 | } 27 | 28 | MousematEffects.prototype = { 29 | createLoadingAnimation() { 30 | 31 | if (this.loadingFrames == false) { 32 | this.loadingFrame1 = chromaSDK.preCreateMousematEffect("CHROMA_NONE"); 33 | 34 | var data = new Array(15); 35 | for (i = 0; i < 15; i++) data[i] = 0; 36 | 37 | data[14] = 0xa5ff; 38 | 39 | this.loadingFrame2 = chromaSDK.preCreateMousematEffect("CHROMA_CUSTOM", data); 40 | 41 | data[13] = 0xa5ff; 42 | 43 | this.loadingFrame3 = chromaSDK.preCreateMousematEffect("CHROMA_CUSTOM", data); 44 | 45 | data[12] = 0xa5ff; 46 | 47 | this.loadingFrame4 = chromaSDK.preCreateMousematEffect("CHROMA_CUSTOM", data); 48 | 49 | data[11] = 0xa5ff; 50 | 51 | this.loadingFrame5 = chromaSDK.preCreateMousematEffect("CHROMA_CUSTOM", data); 52 | 53 | data[10] = 0xa5ff; 54 | 55 | this.loadingFrame6 = chromaSDK.preCreateMousematEffect("CHROMA_CUSTOM", data); 56 | 57 | data[9] = 0xa5ff; 58 | 59 | this.loadingFrame7 = chromaSDK.preCreateMousematEffect("CHROMA_CUSTOM", data); 60 | 61 | data[8] = 0xa5ff; 62 | 63 | this.loadingFrame8 = chromaSDK.preCreateMousematEffect("CHROMA_CUSTOM", data); 64 | 65 | data[7] = 0xa5ff; 66 | 67 | this.loadingFrame9 = chromaSDK.preCreateMousematEffect("CHROMA_CUSTOM", data); 68 | 69 | data[6] = 0xa5ff; 70 | 71 | this.loadingFrame10 = chromaSDK.preCreateMousematEffect("CHROMA_CUSTOM", data); 72 | 73 | data[5] = 0xa5ff; 74 | 75 | this.loadingFrame11 = chromaSDK.preCreateMousematEffect("CHROMA_CUSTOM", data); 76 | 77 | data[4] = 0xa5ff; 78 | 79 | this.loadingFrame12 = chromaSDK.preCreateMousematEffect("CHROMA_CUSTOM", data); 80 | 81 | data[3] = 0xa5ff; 82 | 83 | this.loadingFrame13 = chromaSDK.preCreateMousematEffect("CHROMA_CUSTOM", data); 84 | 85 | data[2] = 0xa5ff; 86 | 87 | this.loadingFrame12 = chromaSDK.preCreateMousematEffect("CHROMA_CUSTOM", data); 88 | 89 | data[1] = 0xa5ff; 90 | 91 | this.loadingFrame11 = chromaSDK.preCreateMousematEffect("CHROMA_CUSTOM", data); 92 | 93 | this.loadingFrame12 = chromaSDK.preCreateMousematEffect("CHROMA_STATIC", 0xa5ff); 94 | 95 | this.loadingFrames = true; 96 | } 97 | 98 | chromaSDK.setEffect(this.loadingFrame1); 99 | 100 | sleep(500); 101 | 102 | chromaSDK.setEffect(this.loadingFrame2); 103 | 104 | sleep(50); 105 | 106 | chromaSDK.setEffect(this.loadingFrame3); 107 | 108 | sleep(50); 109 | 110 | chromaSDK.setEffect(this.loadingFrame4); 111 | 112 | sleep(50); 113 | 114 | chromaSDK.setEffect(this.loadingFrame5); 115 | 116 | sleep(50); 117 | 118 | chromaSDK.setEffect(this.loadingFrame6); 119 | 120 | sleep(50); 121 | 122 | chromaSDK.setEffect(this.loadingFrame7); 123 | 124 | sleep(50); 125 | 126 | chromaSDK.setEffect(this.loadingFrame8); 127 | 128 | sleep(50); 129 | 130 | chromaSDK.setEffect(this.loadingFrame9); 131 | 132 | sleep(50); 133 | 134 | chromaSDK.setEffect(this.loadingFrame10); 135 | 136 | sleep(50); 137 | 138 | chromaSDK.setEffect(this.loadingFrame11); 139 | 140 | sleep(50); 141 | 142 | chromaSDK.setEffect(this.loadingFrame12); 143 | 144 | sleep(50); 145 | }, 146 | createHealthAmmoMana: function (type, value) { 147 | var steps = Math.ceil(value / 100.0 * 5); 148 | 149 | var data = new Array(15); 150 | for (i = 0; i < 15; i++) { 151 | data[i] = 0; 152 | } 153 | 154 | if (type == 1) { // Health 155 | var green = (value / 100.0) * 0xff; 156 | var red = 0xff - ((value / 100.0) * 0xff); 157 | var color = (green) << 8 | red; 158 | 159 | for (i = 0; i < steps; i++) { 160 | data[10 + i] = color; 161 | } 162 | } else if (type == 2) { // Ammo 163 | for (i = 0; i < steps; i++) { 164 | data[4 - i] = 0xffff; 165 | } 166 | } 167 | 168 | chromaSDK.createMousematEffect("CHROMA_CUSTOM", data); 169 | }, 170 | createAlerts: function (type) { 171 | if (this.alertFrames == false) { 172 | this.positiveAlert = chromaSDK.preCreateMousematEffect("CHROMA_STATIC", 0xff00); 173 | this.negativeAlert = chromaSDK.preCreateMousematEffect("CHROMA_STATIC", 0xff); 174 | this.noAlert = chromaSDK.preCreateMousematEffect("CHROMA_NONE"); 175 | this.alertFrames = true; 176 | } 177 | 178 | if (type == 1) { 179 | chromaSDK.setEffect(this.noAlert); 180 | 181 | sleep(200); 182 | 183 | chromaSDK.setEffect(this.positiveAlert); 184 | 185 | sleep(200); 186 | 187 | chromaSDK.setEffect(this.noAlert); 188 | 189 | sleep(200); 190 | 191 | chromaSDK.setEffect(this.positiveAlert); 192 | 193 | sleep(200); 194 | 195 | chromaSDK.setEffect(this.noAlert); 196 | 197 | sleep(200); 198 | 199 | chromaSDK.setEffect(this.positiveAlert); 200 | 201 | sleep(200); 202 | 203 | chromaSDK.setEffect(this.noAlert); 204 | 205 | 206 | } else if (type == 0) { 207 | 208 | chromaSDK.setEffect(this.noAlert); 209 | 210 | sleep(200); 211 | 212 | chromaSDK.setEffect(this.negativeAlert); 213 | 214 | sleep(200); 215 | 216 | chromaSDK.setEffect(this.noAlert); 217 | 218 | sleep(200); 219 | 220 | chromaSDK.setEffect(this.negativeAlert); 221 | 222 | sleep(200); 223 | 224 | chromaSDK.setEffect(this.noAlert); 225 | 226 | sleep(200); 227 | 228 | chromaSDK.setEffect(this.negativeAlert); 229 | 230 | sleep(200); 231 | 232 | chromaSDK.setEffect(this.noAlert); 233 | } 234 | }, 235 | createCooldownTimer(value) { 236 | var steps = Math.ceil(15 * (value / 100.0)); 237 | 238 | var data = new Array(15); 239 | 240 | for (i = 0; i < 15; i++) { 241 | if (i < steps) { 242 | data[i] = 0xff 243 | } else { 244 | data[i] = 0; 245 | } 246 | } 247 | 248 | chromaSDK.createMousematEffect("CHROMA_CUSTOM", data); 249 | }, 250 | createDamageTaken: function(){ 251 | 252 | if (this.damageFrames == false) { 253 | this.damageOn = chromaSDK.preCreateMousematEffect("CHROMA_STATIC", 0xff); 254 | 255 | this.damageOff = chromaSDK.preCreateMousematEffect("CHROMA_NONE"); 256 | this.damageFrames = true; 257 | } 258 | 259 | chromaSDK.setEffect(this.damageOn); 260 | 261 | sleep(50); 262 | 263 | chromaSDK.setEffect(this.damageOff); 264 | }, 265 | free: function(){ 266 | if (this.loadingFrames == true) { 267 | chromaSDK.deleteEffect(this.loadingFrame1); 268 | chromaSDK.deleteEffect(this.loadingFrame2); 269 | chromaSDK.deleteEffect(this.loadingFrame3); 270 | chromaSDK.deleteEffect(this.loadingFrame4); 271 | chromaSDK.deleteEffect(this.loadingFrame5); 272 | chromaSDK.deleteEffect(this.loadingFrame6); 273 | chromaSDK.deleteEffect(this.loadingFrame7); 274 | chromaSDK.deleteEffect(this.loadingFrame8); 275 | chromaSDK.deleteEffect(this.loadingFrame9); 276 | chromaSDK.deleteEffect(this.loadingFrame10); 277 | chromaSDK.deleteEffect(this.loadingFrame11); 278 | chromaSDK.deleteEffect(this.loadingFrame12); 279 | this.loadingFrames = false; 280 | } 281 | 282 | if (this.alertFrames == true) { 283 | chromaSDK.deleteEffect(this.positiveAlert); 284 | chromaSDK.deleteEffect(this.negativeAlert); 285 | chromaSDK.deleteEffect(this.noAlert); 286 | this.alertFrames = false; 287 | } 288 | 289 | if (this.damageFrames == true) { 290 | chromaSDK.deleteEffect(this.damageOn); 291 | chromaSDK.deleteEffect(this.damageOff); 292 | this.damageFrames = false; 293 | } 294 | } 295 | } 296 | -------------------------------------------------------------------------------- /PlayAnimationSample.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 54 | 55 | 56 | 57 | 58 | 59 | 60 |

Control:

61 | 62 | 63 |
64 | 65 |

Composites:

66 | 67 |
71 | 72 | 73 | 74 | 75 |
76 | 77 |

Animations:

78 | 79 | 80 | 81 |
82 | 83 | 84 | 85 |
86 | 87 | 88 | 89 | 90 |
91 | 92 | 93 | 94 |
95 | 96 | 97 | 98 |
99 | 100 | 101 | 102 |
103 | 104 |

Static Color:

105 | 106 | 107 | 108 | 109 | 110 | 111 | 112 |
113 | ALL: 114 | 115 | 116 | 117 | 118 | 119 | 120 | 121 |
122 | 123 |

Stop:

124 | 125 | 126 | 127 | 128 | 129 | 130 |
131 | ALL: 132 | 133 |
134 | 135 |

Clear:

136 | 137 | 138 | 139 | 140 | 141 | 142 |
143 |
144 | ALL:
145 |
146 | 147 | 148 | 149 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # Latest 2 | 3 | * Note: Visit the [Chroma Animation Guide](https://chroma.razer.com/ChromaGuide/) to find the latest supported plugin for Chroma RGB. 4 | 5 | # HTML5ChromaSDK - JS Library for playing Chroma animations 6 | 7 | - [REST Sample App](http://developer.razerzone.com/works-with-chroma/download/) - This repository expands from the sample app to include support for `Chroma` animation playback. 8 | 9 | **Table of Contents** 10 | 11 | * [See also](#see-also) 12 | * [Prerequisites](#prerequisites) 13 | * [Quick Start](#quick-start) 14 | * [Assets](#assets) 15 | * [API](#api) 16 | 17 | 18 | ## See Also 19 | 20 | **Docs:** 21 | 22 | - [Chroma Animation Guide](http://chroma.razer.com/ChromaGuide/) - Visual examples of the Chroma Animation API methods 23 | 24 | **Plugins:** 25 | 26 | - [CChromaEditor](https://github.com/RazerOfficial/CChromaEditor) - C++ native MFC library for playing and editing Chroma animations 27 | 28 | 29 | ## Prerequisites 30 | 31 | * Install [Synapse](https://www.razer.com/synapse-3) 32 | 33 | * Make sure the Chroma Connect module is installed. 34 | 35 | ![image_5](images/image_5.png) 36 | 37 | * If you don't have Chroma hardware, you can see Chroma effects with the [Chroma Emulator](https://github.com/razerofficial/ChromaEmulator) 38 | 39 | - (Optional) [Node.js](https://nodejs.org/en/) - Use to host the sample locally 40 | 41 | 42 | ## Quick Start 43 | 44 | * [Template.html](Template.html) [Template.js](Template.js) 45 | 46 | 47 | 48 | ## Getting Started 49 | 50 | **Browser Security** 51 | 52 | In order to allow an HTML5 page to talk with the Chroma REST API (cross-site scripting), add the response header for `Access-Control-Allow-Origin`. 53 | 54 |
 55 | Access-Control-Allow-Origin: https://chromasdk.io:54236/*
 56 | 
57 | 58 | ![image_3](images/image_3.png) 59 | 60 | 61 | **Node.JS** (Optional) The sample project can be hosted in `Node.js` 62 | 63 | 1 Install `Node.js` 64 | 65 | 2 Open a terminal in the project folder 66 | 67 | 3 Install `Node.js` dependencies 68 | 69 | ``` 70 | npm install 71 | ``` 72 | 73 | 4 Start the server 74 | 75 | ``` 76 | node ServerNode.js 77 | ``` 78 | 79 | 5 Browse the `Node.js` server and pick one of the samples at [http://localhost:1337/](http://localhost:1337/) 80 | 81 | **Hosted** 82 | 83 | 1 Upload the project files to an online website 84 | 85 | 2 Browse `PlayAnimationSample.html` 86 | 87 | ![image_2](images/image_2.png) 88 | 89 | 3 Browse `RazerChromaSDKSampleApplication.html` 90 | 91 | ![image_1](images/image_1.png) 92 | 93 | 4 Browse 'LayerSample.html' 94 | 95 | ![image_4](images/image_4.png) 96 | 97 | 98 | ## Assets 99 | 100 | This library supports the `Chroma` animation exports from [UE4](https://github.com/RazerOfficial/UE4ChromaSDK), [Unity](https://github.com/RazerOfficial/UnityNativeChromaSDK/), and [GameMaker](https://github.com/RazerOfficial/GameMakerChromaExtension). 101 | 102 | **Import Animation From Unity** 103 | 104 | 105 | 106 | * The same `Chroma` animation files can be played on HTTP and HTTPS websites. 107 | 108 | 109 | ## API 110 | 111 | --- 112 | 113 | **Initialization** 114 | 115 | Include the `JS` includes to get access to the `API`. 116 | 117 | ```js 118 | 119 | 120 | 121 | 122 | 123 | ``` 124 | 125 | Initialize/Uninitialize the `Chroma` SDK from the body events. 126 | 127 | ```js 128 | 140 | 141 | ``` 142 | 143 | --- 144 | 145 | **Clear** 146 | 147 | The `clear` method will turn off the lighting effect for a device. 148 | 149 | ```js 150 | ChromaAnimation.clear(EChromaSDKDeviceEnum.DE_ChromaLink); 151 | ChromaAnimation.clear(EChromaSDKDeviceEnum.DE_Headset); 152 | ChromaAnimation.clear(EChromaSDKDeviceEnum.DE_Keyboard); 153 | ChromaAnimation.clear(EChromaSDKDeviceEnum.DE_Keypad); 154 | ChromaAnimation.clear(EChromaSDKDeviceEnum.DE_Mouse); 155 | ChromaAnimation.clear(EChromaSDKDeviceEnum.DE_Mousepad); 156 | ``` 157 | 158 | --- 159 | 160 | **Clear All** 161 | 162 | The `clearAll` method sets the clear state for all devices. 163 | 164 | ```js 165 | ChromaAnimation.clearAll(); 166 | ``` 167 | 168 | --- 169 | 170 | **Static Color** 171 | 172 | The `staticColor` method will set the `Chroma` lighting to all the same color for the device, given a color. 173 | 174 | ```js 175 | var red = 0xFF; 176 | var green = 0xFF00 177 | var blue = 0xFF0000; 178 | var white = 0xFFFFFF; 179 | var color = white; 180 | ChromaAnimation.staticColor(EChromaSDKDeviceEnum.DE_ChromaLink, color); 181 | ChromaAnimation.staticColor(EChromaSDKDeviceEnum.DE_Headset, color); 182 | ChromaAnimation.staticColor(EChromaSDKDeviceEnum.DE_Keyboard, color); 183 | ChromaAnimation.staticColor(EChromaSDKDeviceEnum.DE_Keypad, color); 184 | ChromaAnimation.staticColor(EChromaSDKDeviceEnum.DE_Mouse, color); 185 | ChromaAnimation.staticColor(EChromaSDKDeviceEnum.DE_Mousepad, color); 186 | ``` 187 | 188 | --- 189 | 190 | **Play Animation** 191 | 192 | The `playAnimation` method will play a `Chroma` animation file. With `loop` set to `true`, the animation will repeat. With `loop` set to `false`, the animation will play once. 193 | 194 | ```js 195 | var loop = true; 196 | ChromaAnimation.playAnimation('Random_ChromaLink.chroma', loop); 197 | ChromaAnimation.playAnimation('Random_Headset.chroma', loop); 198 | ChromaAnimation.playAnimation('Random_Keyboard.chroma', loop); 199 | ChromaAnimation.playAnimation('Random_Keypad.chroma', loop); 200 | ChromaAnimation.playAnimation('Random_Mouse.chroma', loop); 201 | ChromaAnimation.playAnimation('Random_Mousepad.chroma', loop); 202 | ``` 203 | 204 | --- 205 | 206 | **Stop Animation** 207 | 208 | The `stopAnimation` method will stop playing a `Chroma` animation file. 209 | 210 | ```js 211 | ChromaAnimation.stopAnimation('Random_ChromaLink.chroma'); 212 | ChromaAnimation.stopAnimation('Random_Headset.chroma'); 213 | ChromaAnimation.stopAnimation('Random_Keyboard.chroma'); 214 | ChromaAnimation.stopAnimation('Random_Keypad.chroma'); 215 | ChromaAnimation.stopAnimation('Random_Mouse.chroma'); 216 | ChromaAnimation.stopAnimation('Random_Mousepad.chroma'); 217 | ``` 218 | 219 | --- 220 | 221 | **Stop All** 222 | 223 | The `stopAll` method stops all animations from playing for all devices. 224 | 225 | ```js 226 | ChromaAnimation.stopAll(); 227 | ``` 228 | 229 | --- 230 | 231 | **Play Composite** 232 | 233 | The `playComposite` method will play a set of `Chroma` animation files. With `loop` set to `true`, the animations will repeat. With `loop` set to `false`, the animations will play once. 234 | 235 | ```js 236 | var loop = true; 237 | ChromaAnimation.playComposite('Random', loop); 238 | 239 | // playComposite will play the set of animations 240 | //ChromaAnimation.playAnimation('Random_ChromaLink.chroma', loop); 241 | //ChromaAnimation.playAnimation('Random_Headset.chroma', loop); 242 | //ChromaAnimation.playAnimation('Random_Keyboard.chroma', loop); 243 | //ChromaAnimation.playAnimation('Random_Keypad.chroma', loop); 244 | //ChromaAnimation.playAnimation('Random_Mouse.chroma', loop); 245 | //ChromaAnimation.playAnimation('Random_Mousepad.chroma', loop); 246 | ``` 247 | 248 | --- 249 | 250 | **Open Animation** 251 | 252 | The `openAnimation` method downloads a `Chroma` animation and invokes a callback after the animation has loaded. 253 | 254 | ```js 255 | var baseLayer = "EnvironmentSnow_Keyboard.chroma"; 256 | 257 | // open animation 258 | ChromaAnimation.openAnimation(baseLayer, function(baseAnimation) { 259 | }); 260 | ``` 261 | 262 | --- 263 | 264 | **Close Animation** 265 | 266 | The `closeAnimation` method stops an animation if playing and then removes the animation so that it can be reloaded. This allows an animation to go back to the original state before any modifications had taken place. 267 | 268 | ```js 269 | var baseLayer = "EnvironmentSnow_Keyboard.chroma"; 270 | 271 | //reset animation 272 | ChromaAnimation.closeAnimation(baseLayer); 273 | 274 | //open animation 275 | ChromaAnimation.openAnimation(baseLayer, function(baseAnimation) { 276 | }); 277 | ``` 278 | 279 | --- 280 | 281 | **Multiply Intensity All Frames** 282 | 283 | The `multiplyIntensityAllFrames` method multiplies a color intensity for all frames of an animation. This is useful to control the intensity of a layer. `0.0` results in a completely black layer. `0.5` would half the color values for all frames. 284 | 285 | ```js 286 | var baseLayer = "EnvironmentSnow_Keyboard.chroma"; 287 | 288 | // reset animation 289 | ChromaAnimation.closeAnimation(baseLayer); 290 | 291 | // open animation 292 | ChromaAnimation.openAnimation(baseLayer, function(baseAnimation) { 293 | 294 | // set base intensity 295 | ChromaAnimation.multiplyIntensityAllFrames(baseLayer, (baseIntensity.value / 100.0)); 296 | 297 | }); 298 | ``` 299 | 300 | --- 301 | 302 | **Offset Nonzero Colors All Frames** 303 | 304 | The `offsetNonZeroColorsAllFrames` method offsets the RGB values for all frames in the animation that aren't black. This method allows a gray animation layer to be tinted to any color while keeping the black colors black. Red, green, blue use expected values `0` to `255`. 305 | 306 | ```js 307 | var layer2 = "RingGray_Keyboard.chroma"; 308 | 309 | // reset animation 310 | ChromaAnimation.closeAnimation(layer2); 311 | 312 | // open animation 313 | ChromaAnimation.openAnimation(layer2, function(layer2Animation) { 314 | 315 | // set base intensity 316 | ChromaAnimation.multiplyIntensityAllFrames(layer2, 317 | (effectIntensity.value / 100.0)); 318 | 319 | //animation starts with 127,127,127 so adding 127,-127,-127 results in 255,0,0 or red 320 | ChromaAnimation.offsetNonZeroColorsAllFrames(layer2, 127, -127, -127); 321 | 322 | }); 323 | ``` 324 | 325 | --- 326 | 327 | **Copy NonZero All Keys All Frames** 328 | 329 | The `copyNonZeroAllKeysAllFrames` method copies all non-black colors for all frames from a source animation to a target animation. This is useful for combining multiple layers into a base layer. 330 | 331 | ```js 332 | ChromaAnimation.copyNonZeroAllKeysAllFrames(sourceAnimationName, targetAnimationName); 333 | ``` 334 | 335 | --- 336 | 337 | **Copy Keys Colors All Frames** 338 | 339 | The `copyKeysColorAllFrames` method copies all specified keys from one source animation to a target animation. 340 | 341 | ```js 342 | // set wasd keys 343 | var keys = []; 344 | keys.push(RZKEY.RZKEY_W); 345 | keys.push(RZKEY.RZKEY_A); 346 | keys.push(RZKEY.RZKEY_S); 347 | keys.push(RZKEY.RZKEY_D); 348 | 349 | ChromaAnimation.copyKeysColorAllFrames(sourceAnimationName, targetAnimationName, keys); 350 | ``` 351 | 352 | --- 353 | -------------------------------------------------------------------------------- /Random_ChromaLink.chroma: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/razerofficial/HTML5ChromaSDK/ec61d7a1924a6facc0e136a84a00b8b87f7ce4ba/Random_ChromaLink.chroma -------------------------------------------------------------------------------- /Random_Headset.chroma: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/razerofficial/HTML5ChromaSDK/ec61d7a1924a6facc0e136a84a00b8b87f7ce4ba/Random_Headset.chroma -------------------------------------------------------------------------------- /Random_Keyboard.chroma: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/razerofficial/HTML5ChromaSDK/ec61d7a1924a6facc0e136a84a00b8b87f7ce4ba/Random_Keyboard.chroma -------------------------------------------------------------------------------- /Random_Keypad.chroma: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/razerofficial/HTML5ChromaSDK/ec61d7a1924a6facc0e136a84a00b8b87f7ce4ba/Random_Keypad.chroma -------------------------------------------------------------------------------- /Random_Mouse.chroma: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/razerofficial/HTML5ChromaSDK/ec61d7a1924a6facc0e136a84a00b8b87f7ce4ba/Random_Mouse.chroma -------------------------------------------------------------------------------- /Random_Mousepad.chroma: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/razerofficial/HTML5ChromaSDK/ec61d7a1924a6facc0e136a84a00b8b87f7ce4ba/Random_Mousepad.chroma -------------------------------------------------------------------------------- /RazerChromaSDKSampleApplication.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | Razer Chroma SDK Sample Application 6 | 7 | 8 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 197 | 198 | 199 |
200 |
201 | Keyboards 202 | Mousemats 203 | Mice 204 | Headsets 205 | Keypads 206 | Chroma Linked Devices 207 |
208 | 209 |
210 |

211 |

212 |

213 |

214 |

215 |

216 | 217 |

218 |
219 | 220 |
221 |

222 |

223 |

224 |

225 |

226 |
227 | 228 |
229 |

230 |

231 |

232 |

233 |
234 | 235 |
236 |

237 |

238 |

239 |
240 | 241 |
242 |

243 |

244 |

245 |

246 |

247 |

248 | 249 |

250 |
251 | 252 |
253 |

254 |

255 |

256 |

257 |
258 |

*Tested in IE 11

259 |
260 | 261 | 269 | 278 | 286 | 294 | 295 | 320 | 321 | 322 | -------------------------------------------------------------------------------- /RazerGreen_ChromaLink.chroma: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/razerofficial/HTML5ChromaSDK/ec61d7a1924a6facc0e136a84a00b8b87f7ce4ba/RazerGreen_ChromaLink.chroma -------------------------------------------------------------------------------- /RazerGreen_Headset.chroma: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/razerofficial/HTML5ChromaSDK/ec61d7a1924a6facc0e136a84a00b8b87f7ce4ba/RazerGreen_Headset.chroma -------------------------------------------------------------------------------- /RazerGreen_Keyboard.chroma: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/razerofficial/HTML5ChromaSDK/ec61d7a1924a6facc0e136a84a00b8b87f7ce4ba/RazerGreen_Keyboard.chroma -------------------------------------------------------------------------------- /RazerGreen_Keypad.chroma: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/razerofficial/HTML5ChromaSDK/ec61d7a1924a6facc0e136a84a00b8b87f7ce4ba/RazerGreen_Keypad.chroma -------------------------------------------------------------------------------- /RazerGreen_Mouse.chroma: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/razerofficial/HTML5ChromaSDK/ec61d7a1924a6facc0e136a84a00b8b87f7ce4ba/RazerGreen_Mouse.chroma -------------------------------------------------------------------------------- /RazerGreen_Mousepad.chroma: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/razerofficial/HTML5ChromaSDK/ec61d7a1924a6facc0e136a84a00b8b87f7ce4ba/RazerGreen_Mousepad.chroma -------------------------------------------------------------------------------- /RingGray_ChromaLink.chroma: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/razerofficial/HTML5ChromaSDK/ec61d7a1924a6facc0e136a84a00b8b87f7ce4ba/RingGray_ChromaLink.chroma -------------------------------------------------------------------------------- /RingGray_Headset.chroma: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/razerofficial/HTML5ChromaSDK/ec61d7a1924a6facc0e136a84a00b8b87f7ce4ba/RingGray_Headset.chroma -------------------------------------------------------------------------------- /RingGray_Keyboard.chroma: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/razerofficial/HTML5ChromaSDK/ec61d7a1924a6facc0e136a84a00b8b87f7ce4ba/RingGray_Keyboard.chroma -------------------------------------------------------------------------------- /RingGray_Keypad.chroma: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/razerofficial/HTML5ChromaSDK/ec61d7a1924a6facc0e136a84a00b8b87f7ce4ba/RingGray_Keypad.chroma -------------------------------------------------------------------------------- /RingGray_Mouse.chroma: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/razerofficial/HTML5ChromaSDK/ec61d7a1924a6facc0e136a84a00b8b87f7ce4ba/RingGray_Mouse.chroma -------------------------------------------------------------------------------- /RingGray_Mousepad.chroma: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/razerofficial/HTML5ChromaSDK/ec61d7a1924a6facc0e136a84a00b8b87f7ce4ba/RingGray_Mousepad.chroma -------------------------------------------------------------------------------- /ScriptInstallServer.cmd: -------------------------------------------------------------------------------- 1 | CALL npm install 2 | PAUSE 3 | -------------------------------------------------------------------------------- /ScriptStartServer.cmd: -------------------------------------------------------------------------------- 1 | start "" "http://localhost:5001/index.html" 2 | node ServerNode.js 3 | -------------------------------------------------------------------------------- /ServerNode.js: -------------------------------------------------------------------------------- 1 | const express = require('express'); 2 | const app = express(); 3 | app.use(function (req, res, next) { 4 | res.setHeader('Access-Control-Allow-Origin', '*'); 5 | next(); 6 | }); 7 | 8 | app.use(express.static('.')); 9 | 10 | app.listen(5001, function () { 11 | console.log('Example app listening on port 5001!'); 12 | }) 13 | -------------------------------------------------------------------------------- /TabbedDlg.css: -------------------------------------------------------------------------------- 1 | /* Style the tab */ 2 | div.tab { 3 | overflow: hidden; 4 | border: 1px solid #ccc; 5 | background-color: #f1f1f1; 6 | } 7 | 8 | /* Style the links inside the tab */ 9 | div.tab a { 10 | float: left; 11 | display: block; 12 | color: black; 13 | text-align: center; 14 | padding: 14px 16px; 15 | text-decoration: none; 16 | transition: 0.3s; 17 | font-size: 17px; 18 | } 19 | 20 | /* Change background color of links on hover */ 21 | div.tab a:hover { 22 | background-color: #ddd; 23 | } 24 | 25 | /* Create an active/current tablink class */ 26 | div.tab a:focus, .active { 27 | background-color: #ccc; 28 | } 29 | 30 | /* Style the tab content */ 31 | .tabcontent { 32 | display: none; 33 | padding: 6px 12px; 34 | border: 1px solid #ccc; 35 | border-top: none; 36 | } 37 | -------------------------------------------------------------------------------- /Template.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | Template Animation Sample 6 | 7 | 8 | 9 | Check your hardware for the Chroma animation sample. 10 | 11 | 12 | 13 | 14 | -------------------------------------------------------------------------------- /Template.js: -------------------------------------------------------------------------------- 1 | var chromaSDK = undefined; 2 | var chromaIsInitialized = false; 3 | 4 | function detectChromaSDK() { 5 | if (chromaSDK == undefined) { 6 | chromaSDK = new ChromaSDK(); 7 | } 8 | var oReq = new XMLHttpRequest(); 9 | oReq.timeout = 2000; // time in milliseconds 10 | oReq.addEventListener("load", function() { 11 | var jsonVersion = JSON.parse(this.responseText); 12 | var versionOrBetter = false; 13 | if (jsonVersion != undefined && 14 | jsonVersion.version != undefined) { 15 | var parts = jsonVersion.version.split("."); 16 | if (parts.length >= 3 && 17 | ((parts[0] > 2) || 18 | (parts[0] == 2 && parts[1] > 8) || 19 | (parts[0] == 2 && parts[1] == 8 && parts[2] >= 5))) { 20 | versionOrBetter = true; 21 | } 22 | } 23 | 24 | if (versionOrBetter) { 25 | chromaSDK.init(); 26 | chromaIsInitialized = true; 27 | setTimeout(function() { 28 | pageChromaStart(); 29 | }, 1000); 30 | } else { 31 | // Time to update Synapse 32 | } 33 | }); 34 | oReq.ontimeout = function() { 35 | 36 | if (vue.$data.pageState.btnPlay.state) { 37 | console.log('ChromaSDK timed out!'); 38 | setTimeout(function() { detectChromaSDK(); }, 5000); 39 | } 40 | }; 41 | oReq.onerror = function() { 42 | 43 | if (vue.$data.pageState.btnPlay.state) { 44 | console.log('ChromaSDK HTTP error!'); 45 | setTimeout(function() { detectChromaSDK(); }, 5000); 46 | } 47 | }; 48 | oReq.open("GET", "https://chromasdk.io:54236/razer/chromasdk"); 49 | oReq.send(); 50 | } 51 | 52 | function pageLoaded() { 53 | detectChromaSDK(); 54 | } 55 | 56 | var effectName = 'FireEffect'; 57 | 58 | function showEffectChromaLink() { 59 | var baseLayer = effectName + '_ChromaLink.chroma'; 60 | ChromaAnimation.closeAnimation(baseLayer); 61 | ChromaAnimation.openAnimation(baseLayer, function(baseAnimation) { 62 | ChromaAnimation.playAnimation(baseLayer, true); 63 | }); 64 | }; 65 | 66 | function showEffectHeadset() { 67 | var baseLayer = effectName + '_Headset.chroma'; 68 | ChromaAnimation.closeAnimation(baseLayer); 69 | ChromaAnimation.openAnimation(baseLayer, function(baseAnimation) { 70 | ChromaAnimation.playAnimation(baseLayer, true); 71 | }); 72 | }; 73 | 74 | function showEffectKeyboard() { 75 | var baseLayer = effectName + '_Keyboard.chroma'; 76 | ChromaAnimation.closeAnimation(baseLayer); 77 | ChromaAnimation.openAnimation(baseLayer, function(baseAnimation) { 78 | ChromaAnimation.playAnimation(baseLayer, true); 79 | }); 80 | }; 81 | 82 | function showEffectKeypad() { 83 | var baseLayer = effectName + '_Keypad.chroma'; 84 | ChromaAnimation.closeAnimation(baseLayer); 85 | ChromaAnimation.openAnimation(baseLayer, function(baseAnimation) { 86 | ChromaAnimation.playAnimation(baseLayer, true); 87 | }); 88 | }; 89 | 90 | function showEffectMouse() { 91 | var baseLayer = effectName + '_Mouse.chroma'; 92 | ChromaAnimation.closeAnimation(baseLayer); 93 | ChromaAnimation.openAnimation(baseLayer, function(baseAnimation) { 94 | ChromaAnimation.playAnimation(baseLayer, true); 95 | }); 96 | }; 97 | 98 | function showEffectMousepad() { 99 | var baseLayer = effectName + '_Mousepad.chroma'; 100 | ChromaAnimation.closeAnimation(baseLayer); 101 | ChromaAnimation.openAnimation(baseLayer, function(baseAnimation) { 102 | ChromaAnimation.playAnimation(baseLayer, true); 103 | }); 104 | }; 105 | 106 | function pageChromaStart() { 107 | console.log('Ready to play Chroma!'); 108 | showEffectChromaLink(); 109 | showEffectHeadset(); 110 | showEffectKeyboard(); 111 | showEffectKeypad(); 112 | showEffectMouse(); 113 | showEffectMousepad(); 114 | } 115 | -------------------------------------------------------------------------------- /Wave_ChromaLink.chroma: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/razerofficial/HTML5ChromaSDK/ec61d7a1924a6facc0e136a84a00b8b87f7ce4ba/Wave_ChromaLink.chroma -------------------------------------------------------------------------------- /Wave_Headset.chroma: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/razerofficial/HTML5ChromaSDK/ec61d7a1924a6facc0e136a84a00b8b87f7ce4ba/Wave_Headset.chroma -------------------------------------------------------------------------------- /Wave_Keyboard.chroma: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/razerofficial/HTML5ChromaSDK/ec61d7a1924a6facc0e136a84a00b8b87f7ce4ba/Wave_Keyboard.chroma -------------------------------------------------------------------------------- /Wave_Keypad.chroma: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/razerofficial/HTML5ChromaSDK/ec61d7a1924a6facc0e136a84a00b8b87f7ce4ba/Wave_Keypad.chroma -------------------------------------------------------------------------------- /Wave_Mouse.chroma: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/razerofficial/HTML5ChromaSDK/ec61d7a1924a6facc0e136a84a00b8b87f7ce4ba/Wave_Mouse.chroma -------------------------------------------------------------------------------- /Wave_Mousepad.chroma: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/razerofficial/HTML5ChromaSDK/ec61d7a1924a6facc0e136a84a00b8b87f7ce4ba/Wave_Mousepad.chroma -------------------------------------------------------------------------------- /favicon.ico: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/razerofficial/HTML5ChromaSDK/ec61d7a1924a6facc0e136a84a00b8b87f7ce4ba/favicon.ico -------------------------------------------------------------------------------- /images/image_1.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/razerofficial/HTML5ChromaSDK/ec61d7a1924a6facc0e136a84a00b8b87f7ce4ba/images/image_1.png -------------------------------------------------------------------------------- /images/image_2.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/razerofficial/HTML5ChromaSDK/ec61d7a1924a6facc0e136a84a00b8b87f7ce4ba/images/image_2.png -------------------------------------------------------------------------------- /images/image_3.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/razerofficial/HTML5ChromaSDK/ec61d7a1924a6facc0e136a84a00b8b87f7ce4ba/images/image_3.png -------------------------------------------------------------------------------- /images/image_4.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/razerofficial/HTML5ChromaSDK/ec61d7a1924a6facc0e136a84a00b8b87f7ce4ba/images/image_4.png -------------------------------------------------------------------------------- /images/image_5.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/razerofficial/HTML5ChromaSDK/ec61d7a1924a6facc0e136a84a00b8b87f7ce4ba/images/image_5.png -------------------------------------------------------------------------------- /index.html: -------------------------------------------------------------------------------- 1 | 2 | Template.html
3 | PlayAnimationSample.html
4 | LayerSample.html
5 | RazerChromaSDKSampleApplication.html
6 | Colors.html
7 | 8 | -------------------------------------------------------------------------------- /jquery-3.3.1.min.js: -------------------------------------------------------------------------------- 1 | /*! jQuery v3.3.1 | (c) JS Foundation and other contributors | jquery.org/license */ 2 | !function(e,t){"use strict";"object"==typeof module&&"object"==typeof module.exports?module.exports=e.document?t(e,!0):function(e){if(!e.document)throw new Error("jQuery requires a window with a document");return t(e)}:t(e)}("undefined"!=typeof window?window:this,function(e,t){"use strict";var n=[],r=e.document,i=Object.getPrototypeOf,o=n.slice,a=n.concat,s=n.push,u=n.indexOf,l={},c=l.toString,f=l.hasOwnProperty,p=f.toString,d=p.call(Object),h={},g=function e(t){return"function"==typeof t&&"number"!=typeof t.nodeType},y=function e(t){return null!=t&&t===t.window},v={type:!0,src:!0,noModule:!0};function m(e,t,n){var i,o=(t=t||r).createElement("script");if(o.text=e,n)for(i in v)n[i]&&(o[i]=n[i]);t.head.appendChild(o).parentNode.removeChild(o)}function x(e){return null==e?e+"":"object"==typeof e||"function"==typeof e?l[c.call(e)]||"object":typeof e}var b="3.3.1",w=function(e,t){return new w.fn.init(e,t)},T=/^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g;w.fn=w.prototype={jquery:"3.3.1",constructor:w,length:0,toArray:function(){return o.call(this)},get:function(e){return null==e?o.call(this):e<0?this[e+this.length]:this[e]},pushStack:function(e){var t=w.merge(this.constructor(),e);return t.prevObject=this,t},each:function(e){return w.each(this,e)},map:function(e){return this.pushStack(w.map(this,function(t,n){return e.call(t,n,t)}))},slice:function(){return this.pushStack(o.apply(this,arguments))},first:function(){return this.eq(0)},last:function(){return this.eq(-1)},eq:function(e){var t=this.length,n=+e+(e<0?t:0);return this.pushStack(n>=0&&n0&&t-1 in e)}var E=function(e){var t,n,r,i,o,a,s,u,l,c,f,p,d,h,g,y,v,m,x,b="sizzle"+1*new Date,w=e.document,T=0,C=0,E=ae(),k=ae(),S=ae(),D=function(e,t){return e===t&&(f=!0),0},N={}.hasOwnProperty,A=[],j=A.pop,q=A.push,L=A.push,H=A.slice,O=function(e,t){for(var n=0,r=e.length;n+~]|"+M+")"+M+"*"),z=new RegExp("="+M+"*([^\\]'\"]*?)"+M+"*\\]","g"),X=new RegExp(W),U=new RegExp("^"+R+"$"),V={ID:new RegExp("^#("+R+")"),CLASS:new RegExp("^\\.("+R+")"),TAG:new RegExp("^("+R+"|[*])"),ATTR:new RegExp("^"+I),PSEUDO:new RegExp("^"+W),CHILD:new RegExp("^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\("+M+"*(even|odd|(([+-]|)(\\d*)n|)"+M+"*(?:([+-]|)"+M+"*(\\d+)|))"+M+"*\\)|)","i"),bool:new RegExp("^(?:"+P+")$","i"),needsContext:new RegExp("^"+M+"*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\("+M+"*((?:-\\d)?\\d*)"+M+"*\\)|)(?=[^-]|$)","i")},G=/^(?:input|select|textarea|button)$/i,Y=/^h\d$/i,Q=/^[^{]+\{\s*\[native \w/,J=/^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/,K=/[+~]/,Z=new RegExp("\\\\([\\da-f]{1,6}"+M+"?|("+M+")|.)","ig"),ee=function(e,t,n){var r="0x"+t-65536;return r!==r||n?t:r<0?String.fromCharCode(r+65536):String.fromCharCode(r>>10|55296,1023&r|56320)},te=/([\0-\x1f\x7f]|^-?\d)|^-$|[^\0-\x1f\x7f-\uFFFF\w-]/g,ne=function(e,t){return t?"\0"===e?"\ufffd":e.slice(0,-1)+"\\"+e.charCodeAt(e.length-1).toString(16)+" ":"\\"+e},re=function(){p()},ie=me(function(e){return!0===e.disabled&&("form"in e||"label"in e)},{dir:"parentNode",next:"legend"});try{L.apply(A=H.call(w.childNodes),w.childNodes),A[w.childNodes.length].nodeType}catch(e){L={apply:A.length?function(e,t){q.apply(e,H.call(t))}:function(e,t){var n=e.length,r=0;while(e[n++]=t[r++]);e.length=n-1}}}function oe(e,t,r,i){var o,s,l,c,f,h,v,m=t&&t.ownerDocument,T=t?t.nodeType:9;if(r=r||[],"string"!=typeof e||!e||1!==T&&9!==T&&11!==T)return r;if(!i&&((t?t.ownerDocument||t:w)!==d&&p(t),t=t||d,g)){if(11!==T&&(f=J.exec(e)))if(o=f[1]){if(9===T){if(!(l=t.getElementById(o)))return r;if(l.id===o)return r.push(l),r}else if(m&&(l=m.getElementById(o))&&x(t,l)&&l.id===o)return r.push(l),r}else{if(f[2])return L.apply(r,t.getElementsByTagName(e)),r;if((o=f[3])&&n.getElementsByClassName&&t.getElementsByClassName)return L.apply(r,t.getElementsByClassName(o)),r}if(n.qsa&&!S[e+" "]&&(!y||!y.test(e))){if(1!==T)m=t,v=e;else if("object"!==t.nodeName.toLowerCase()){(c=t.getAttribute("id"))?c=c.replace(te,ne):t.setAttribute("id",c=b),s=(h=a(e)).length;while(s--)h[s]="#"+c+" "+ve(h[s]);v=h.join(","),m=K.test(e)&&ge(t.parentNode)||t}if(v)try{return L.apply(r,m.querySelectorAll(v)),r}catch(e){}finally{c===b&&t.removeAttribute("id")}}}return u(e.replace(B,"$1"),t,r,i)}function ae(){var e=[];function t(n,i){return e.push(n+" ")>r.cacheLength&&delete t[e.shift()],t[n+" "]=i}return t}function se(e){return e[b]=!0,e}function ue(e){var t=d.createElement("fieldset");try{return!!e(t)}catch(e){return!1}finally{t.parentNode&&t.parentNode.removeChild(t),t=null}}function le(e,t){var n=e.split("|"),i=n.length;while(i--)r.attrHandle[n[i]]=t}function ce(e,t){var n=t&&e,r=n&&1===e.nodeType&&1===t.nodeType&&e.sourceIndex-t.sourceIndex;if(r)return r;if(n)while(n=n.nextSibling)if(n===t)return-1;return e?1:-1}function fe(e){return function(t){return"input"===t.nodeName.toLowerCase()&&t.type===e}}function pe(e){return function(t){var n=t.nodeName.toLowerCase();return("input"===n||"button"===n)&&t.type===e}}function de(e){return function(t){return"form"in t?t.parentNode&&!1===t.disabled?"label"in t?"label"in t.parentNode?t.parentNode.disabled===e:t.disabled===e:t.isDisabled===e||t.isDisabled!==!e&&ie(t)===e:t.disabled===e:"label"in t&&t.disabled===e}}function he(e){return se(function(t){return t=+t,se(function(n,r){var i,o=e([],n.length,t),a=o.length;while(a--)n[i=o[a]]&&(n[i]=!(r[i]=n[i]))})})}function ge(e){return e&&"undefined"!=typeof e.getElementsByTagName&&e}n=oe.support={},o=oe.isXML=function(e){var t=e&&(e.ownerDocument||e).documentElement;return!!t&&"HTML"!==t.nodeName},p=oe.setDocument=function(e){var t,i,a=e?e.ownerDocument||e:w;return a!==d&&9===a.nodeType&&a.documentElement?(d=a,h=d.documentElement,g=!o(d),w!==d&&(i=d.defaultView)&&i.top!==i&&(i.addEventListener?i.addEventListener("unload",re,!1):i.attachEvent&&i.attachEvent("onunload",re)),n.attributes=ue(function(e){return e.className="i",!e.getAttribute("className")}),n.getElementsByTagName=ue(function(e){return e.appendChild(d.createComment("")),!e.getElementsByTagName("*").length}),n.getElementsByClassName=Q.test(d.getElementsByClassName),n.getById=ue(function(e){return h.appendChild(e).id=b,!d.getElementsByName||!d.getElementsByName(b).length}),n.getById?(r.filter.ID=function(e){var t=e.replace(Z,ee);return function(e){return e.getAttribute("id")===t}},r.find.ID=function(e,t){if("undefined"!=typeof t.getElementById&&g){var n=t.getElementById(e);return n?[n]:[]}}):(r.filter.ID=function(e){var t=e.replace(Z,ee);return function(e){var n="undefined"!=typeof e.getAttributeNode&&e.getAttributeNode("id");return n&&n.value===t}},r.find.ID=function(e,t){if("undefined"!=typeof t.getElementById&&g){var n,r,i,o=t.getElementById(e);if(o){if((n=o.getAttributeNode("id"))&&n.value===e)return[o];i=t.getElementsByName(e),r=0;while(o=i[r++])if((n=o.getAttributeNode("id"))&&n.value===e)return[o]}return[]}}),r.find.TAG=n.getElementsByTagName?function(e,t){return"undefined"!=typeof t.getElementsByTagName?t.getElementsByTagName(e):n.qsa?t.querySelectorAll(e):void 0}:function(e,t){var n,r=[],i=0,o=t.getElementsByTagName(e);if("*"===e){while(n=o[i++])1===n.nodeType&&r.push(n);return r}return o},r.find.CLASS=n.getElementsByClassName&&function(e,t){if("undefined"!=typeof t.getElementsByClassName&&g)return t.getElementsByClassName(e)},v=[],y=[],(n.qsa=Q.test(d.querySelectorAll))&&(ue(function(e){h.appendChild(e).innerHTML="",e.querySelectorAll("[msallowcapture^='']").length&&y.push("[*^$]="+M+"*(?:''|\"\")"),e.querySelectorAll("[selected]").length||y.push("\\["+M+"*(?:value|"+P+")"),e.querySelectorAll("[id~="+b+"-]").length||y.push("~="),e.querySelectorAll(":checked").length||y.push(":checked"),e.querySelectorAll("a#"+b+"+*").length||y.push(".#.+[+~]")}),ue(function(e){e.innerHTML="";var t=d.createElement("input");t.setAttribute("type","hidden"),e.appendChild(t).setAttribute("name","D"),e.querySelectorAll("[name=d]").length&&y.push("name"+M+"*[*^$|!~]?="),2!==e.querySelectorAll(":enabled").length&&y.push(":enabled",":disabled"),h.appendChild(e).disabled=!0,2!==e.querySelectorAll(":disabled").length&&y.push(":enabled",":disabled"),e.querySelectorAll("*,:x"),y.push(",.*:")})),(n.matchesSelector=Q.test(m=h.matches||h.webkitMatchesSelector||h.mozMatchesSelector||h.oMatchesSelector||h.msMatchesSelector))&&ue(function(e){n.disconnectedMatch=m.call(e,"*"),m.call(e,"[s!='']:x"),v.push("!=",W)}),y=y.length&&new RegExp(y.join("|")),v=v.length&&new RegExp(v.join("|")),t=Q.test(h.compareDocumentPosition),x=t||Q.test(h.contains)?function(e,t){var n=9===e.nodeType?e.documentElement:e,r=t&&t.parentNode;return e===r||!(!r||1!==r.nodeType||!(n.contains?n.contains(r):e.compareDocumentPosition&&16&e.compareDocumentPosition(r)))}:function(e,t){if(t)while(t=t.parentNode)if(t===e)return!0;return!1},D=t?function(e,t){if(e===t)return f=!0,0;var r=!e.compareDocumentPosition-!t.compareDocumentPosition;return r||(1&(r=(e.ownerDocument||e)===(t.ownerDocument||t)?e.compareDocumentPosition(t):1)||!n.sortDetached&&t.compareDocumentPosition(e)===r?e===d||e.ownerDocument===w&&x(w,e)?-1:t===d||t.ownerDocument===w&&x(w,t)?1:c?O(c,e)-O(c,t):0:4&r?-1:1)}:function(e,t){if(e===t)return f=!0,0;var n,r=0,i=e.parentNode,o=t.parentNode,a=[e],s=[t];if(!i||!o)return e===d?-1:t===d?1:i?-1:o?1:c?O(c,e)-O(c,t):0;if(i===o)return ce(e,t);n=e;while(n=n.parentNode)a.unshift(n);n=t;while(n=n.parentNode)s.unshift(n);while(a[r]===s[r])r++;return r?ce(a[r],s[r]):a[r]===w?-1:s[r]===w?1:0},d):d},oe.matches=function(e,t){return oe(e,null,null,t)},oe.matchesSelector=function(e,t){if((e.ownerDocument||e)!==d&&p(e),t=t.replace(z,"='$1']"),n.matchesSelector&&g&&!S[t+" "]&&(!v||!v.test(t))&&(!y||!y.test(t)))try{var r=m.call(e,t);if(r||n.disconnectedMatch||e.document&&11!==e.document.nodeType)return r}catch(e){}return oe(t,d,null,[e]).length>0},oe.contains=function(e,t){return(e.ownerDocument||e)!==d&&p(e),x(e,t)},oe.attr=function(e,t){(e.ownerDocument||e)!==d&&p(e);var i=r.attrHandle[t.toLowerCase()],o=i&&N.call(r.attrHandle,t.toLowerCase())?i(e,t,!g):void 0;return void 0!==o?o:n.attributes||!g?e.getAttribute(t):(o=e.getAttributeNode(t))&&o.specified?o.value:null},oe.escape=function(e){return(e+"").replace(te,ne)},oe.error=function(e){throw new Error("Syntax error, unrecognized expression: "+e)},oe.uniqueSort=function(e){var t,r=[],i=0,o=0;if(f=!n.detectDuplicates,c=!n.sortStable&&e.slice(0),e.sort(D),f){while(t=e[o++])t===e[o]&&(i=r.push(o));while(i--)e.splice(r[i],1)}return c=null,e},i=oe.getText=function(e){var t,n="",r=0,o=e.nodeType;if(o){if(1===o||9===o||11===o){if("string"==typeof e.textContent)return e.textContent;for(e=e.firstChild;e;e=e.nextSibling)n+=i(e)}else if(3===o||4===o)return e.nodeValue}else while(t=e[r++])n+=i(t);return n},(r=oe.selectors={cacheLength:50,createPseudo:se,match:V,attrHandle:{},find:{},relative:{">":{dir:"parentNode",first:!0}," ":{dir:"parentNode"},"+":{dir:"previousSibling",first:!0},"~":{dir:"previousSibling"}},preFilter:{ATTR:function(e){return e[1]=e[1].replace(Z,ee),e[3]=(e[3]||e[4]||e[5]||"").replace(Z,ee),"~="===e[2]&&(e[3]=" "+e[3]+" "),e.slice(0,4)},CHILD:function(e){return e[1]=e[1].toLowerCase(),"nth"===e[1].slice(0,3)?(e[3]||oe.error(e[0]),e[4]=+(e[4]?e[5]+(e[6]||1):2*("even"===e[3]||"odd"===e[3])),e[5]=+(e[7]+e[8]||"odd"===e[3])):e[3]&&oe.error(e[0]),e},PSEUDO:function(e){var t,n=!e[6]&&e[2];return V.CHILD.test(e[0])?null:(e[3]?e[2]=e[4]||e[5]||"":n&&X.test(n)&&(t=a(n,!0))&&(t=n.indexOf(")",n.length-t)-n.length)&&(e[0]=e[0].slice(0,t),e[2]=n.slice(0,t)),e.slice(0,3))}},filter:{TAG:function(e){var t=e.replace(Z,ee).toLowerCase();return"*"===e?function(){return!0}:function(e){return e.nodeName&&e.nodeName.toLowerCase()===t}},CLASS:function(e){var t=E[e+" "];return t||(t=new RegExp("(^|"+M+")"+e+"("+M+"|$)"))&&E(e,function(e){return t.test("string"==typeof e.className&&e.className||"undefined"!=typeof e.getAttribute&&e.getAttribute("class")||"")})},ATTR:function(e,t,n){return function(r){var i=oe.attr(r,e);return null==i?"!="===t:!t||(i+="","="===t?i===n:"!="===t?i!==n:"^="===t?n&&0===i.indexOf(n):"*="===t?n&&i.indexOf(n)>-1:"$="===t?n&&i.slice(-n.length)===n:"~="===t?(" "+i.replace($," ")+" ").indexOf(n)>-1:"|="===t&&(i===n||i.slice(0,n.length+1)===n+"-"))}},CHILD:function(e,t,n,r,i){var o="nth"!==e.slice(0,3),a="last"!==e.slice(-4),s="of-type"===t;return 1===r&&0===i?function(e){return!!e.parentNode}:function(t,n,u){var l,c,f,p,d,h,g=o!==a?"nextSibling":"previousSibling",y=t.parentNode,v=s&&t.nodeName.toLowerCase(),m=!u&&!s,x=!1;if(y){if(o){while(g){p=t;while(p=p[g])if(s?p.nodeName.toLowerCase()===v:1===p.nodeType)return!1;h=g="only"===e&&!h&&"nextSibling"}return!0}if(h=[a?y.firstChild:y.lastChild],a&&m){x=(d=(l=(c=(f=(p=y)[b]||(p[b]={}))[p.uniqueID]||(f[p.uniqueID]={}))[e]||[])[0]===T&&l[1])&&l[2],p=d&&y.childNodes[d];while(p=++d&&p&&p[g]||(x=d=0)||h.pop())if(1===p.nodeType&&++x&&p===t){c[e]=[T,d,x];break}}else if(m&&(x=d=(l=(c=(f=(p=t)[b]||(p[b]={}))[p.uniqueID]||(f[p.uniqueID]={}))[e]||[])[0]===T&&l[1]),!1===x)while(p=++d&&p&&p[g]||(x=d=0)||h.pop())if((s?p.nodeName.toLowerCase()===v:1===p.nodeType)&&++x&&(m&&((c=(f=p[b]||(p[b]={}))[p.uniqueID]||(f[p.uniqueID]={}))[e]=[T,x]),p===t))break;return(x-=i)===r||x%r==0&&x/r>=0}}},PSEUDO:function(e,t){var n,i=r.pseudos[e]||r.setFilters[e.toLowerCase()]||oe.error("unsupported pseudo: "+e);return i[b]?i(t):i.length>1?(n=[e,e,"",t],r.setFilters.hasOwnProperty(e.toLowerCase())?se(function(e,n){var r,o=i(e,t),a=o.length;while(a--)e[r=O(e,o[a])]=!(n[r]=o[a])}):function(e){return i(e,0,n)}):i}},pseudos:{not:se(function(e){var t=[],n=[],r=s(e.replace(B,"$1"));return r[b]?se(function(e,t,n,i){var o,a=r(e,null,i,[]),s=e.length;while(s--)(o=a[s])&&(e[s]=!(t[s]=o))}):function(e,i,o){return t[0]=e,r(t,null,o,n),t[0]=null,!n.pop()}}),has:se(function(e){return function(t){return oe(e,t).length>0}}),contains:se(function(e){return e=e.replace(Z,ee),function(t){return(t.textContent||t.innerText||i(t)).indexOf(e)>-1}}),lang:se(function(e){return U.test(e||"")||oe.error("unsupported lang: "+e),e=e.replace(Z,ee).toLowerCase(),function(t){var n;do{if(n=g?t.lang:t.getAttribute("xml:lang")||t.getAttribute("lang"))return(n=n.toLowerCase())===e||0===n.indexOf(e+"-")}while((t=t.parentNode)&&1===t.nodeType);return!1}}),target:function(t){var n=e.location&&e.location.hash;return n&&n.slice(1)===t.id},root:function(e){return e===h},focus:function(e){return e===d.activeElement&&(!d.hasFocus||d.hasFocus())&&!!(e.type||e.href||~e.tabIndex)},enabled:de(!1),disabled:de(!0),checked:function(e){var t=e.nodeName.toLowerCase();return"input"===t&&!!e.checked||"option"===t&&!!e.selected},selected:function(e){return e.parentNode&&e.parentNode.selectedIndex,!0===e.selected},empty:function(e){for(e=e.firstChild;e;e=e.nextSibling)if(e.nodeType<6)return!1;return!0},parent:function(e){return!r.pseudos.empty(e)},header:function(e){return Y.test(e.nodeName)},input:function(e){return G.test(e.nodeName)},button:function(e){var t=e.nodeName.toLowerCase();return"input"===t&&"button"===e.type||"button"===t},text:function(e){var t;return"input"===e.nodeName.toLowerCase()&&"text"===e.type&&(null==(t=e.getAttribute("type"))||"text"===t.toLowerCase())},first:he(function(){return[0]}),last:he(function(e,t){return[t-1]}),eq:he(function(e,t,n){return[n<0?n+t:n]}),even:he(function(e,t){for(var n=0;n=0;)e.push(r);return e}),gt:he(function(e,t,n){for(var r=n<0?n+t:n;++r1?function(t,n,r){var i=e.length;while(i--)if(!e[i](t,n,r))return!1;return!0}:e[0]}function be(e,t,n){for(var r=0,i=t.length;r-1&&(o[l]=!(a[l]=f))}}else v=we(v===a?v.splice(h,v.length):v),i?i(null,a,v,u):L.apply(a,v)})}function Ce(e){for(var t,n,i,o=e.length,a=r.relative[e[0].type],s=a||r.relative[" "],u=a?1:0,c=me(function(e){return e===t},s,!0),f=me(function(e){return O(t,e)>-1},s,!0),p=[function(e,n,r){var i=!a&&(r||n!==l)||((t=n).nodeType?c(e,n,r):f(e,n,r));return t=null,i}];u1&&xe(p),u>1&&ve(e.slice(0,u-1).concat({value:" "===e[u-2].type?"*":""})).replace(B,"$1"),n,u0,i=e.length>0,o=function(o,a,s,u,c){var f,h,y,v=0,m="0",x=o&&[],b=[],w=l,C=o||i&&r.find.TAG("*",c),E=T+=null==w?1:Math.random()||.1,k=C.length;for(c&&(l=a===d||a||c);m!==k&&null!=(f=C[m]);m++){if(i&&f){h=0,a||f.ownerDocument===d||(p(f),s=!g);while(y=e[h++])if(y(f,a||d,s)){u.push(f);break}c&&(T=E)}n&&((f=!y&&f)&&v--,o&&x.push(f))}if(v+=m,n&&m!==v){h=0;while(y=t[h++])y(x,b,a,s);if(o){if(v>0)while(m--)x[m]||b[m]||(b[m]=j.call(u));b=we(b)}L.apply(u,b),c&&!o&&b.length>0&&v+t.length>1&&oe.uniqueSort(u)}return c&&(T=E,l=w),x};return n?se(o):o}return s=oe.compile=function(e,t){var n,r=[],i=[],o=S[e+" "];if(!o){t||(t=a(e)),n=t.length;while(n--)(o=Ce(t[n]))[b]?r.push(o):i.push(o);(o=S(e,Ee(i,r))).selector=e}return o},u=oe.select=function(e,t,n,i){var o,u,l,c,f,p="function"==typeof e&&e,d=!i&&a(e=p.selector||e);if(n=n||[],1===d.length){if((u=d[0]=d[0].slice(0)).length>2&&"ID"===(l=u[0]).type&&9===t.nodeType&&g&&r.relative[u[1].type]){if(!(t=(r.find.ID(l.matches[0].replace(Z,ee),t)||[])[0]))return n;p&&(t=t.parentNode),e=e.slice(u.shift().value.length)}o=V.needsContext.test(e)?0:u.length;while(o--){if(l=u[o],r.relative[c=l.type])break;if((f=r.find[c])&&(i=f(l.matches[0].replace(Z,ee),K.test(u[0].type)&&ge(t.parentNode)||t))){if(u.splice(o,1),!(e=i.length&&ve(u)))return L.apply(n,i),n;break}}}return(p||s(e,d))(i,t,!g,n,!t||K.test(e)&&ge(t.parentNode)||t),n},n.sortStable=b.split("").sort(D).join("")===b,n.detectDuplicates=!!f,p(),n.sortDetached=ue(function(e){return 1&e.compareDocumentPosition(d.createElement("fieldset"))}),ue(function(e){return e.innerHTML="","#"===e.firstChild.getAttribute("href")})||le("type|href|height|width",function(e,t,n){if(!n)return e.getAttribute(t,"type"===t.toLowerCase()?1:2)}),n.attributes&&ue(function(e){return e.innerHTML="",e.firstChild.setAttribute("value",""),""===e.firstChild.getAttribute("value")})||le("value",function(e,t,n){if(!n&&"input"===e.nodeName.toLowerCase())return e.defaultValue}),ue(function(e){return null==e.getAttribute("disabled")})||le(P,function(e,t,n){var r;if(!n)return!0===e[t]?t.toLowerCase():(r=e.getAttributeNode(t))&&r.specified?r.value:null}),oe}(e);w.find=E,w.expr=E.selectors,w.expr[":"]=w.expr.pseudos,w.uniqueSort=w.unique=E.uniqueSort,w.text=E.getText,w.isXMLDoc=E.isXML,w.contains=E.contains,w.escapeSelector=E.escape;var k=function(e,t,n){var r=[],i=void 0!==n;while((e=e[t])&&9!==e.nodeType)if(1===e.nodeType){if(i&&w(e).is(n))break;r.push(e)}return r},S=function(e,t){for(var n=[];e;e=e.nextSibling)1===e.nodeType&&e!==t&&n.push(e);return n},D=w.expr.match.needsContext;function N(e,t){return e.nodeName&&e.nodeName.toLowerCase()===t.toLowerCase()}var A=/^<([a-z][^\/\0>:\x20\t\r\n\f]*)[\x20\t\r\n\f]*\/?>(?:<\/\1>|)$/i;function j(e,t,n){return g(t)?w.grep(e,function(e,r){return!!t.call(e,r,e)!==n}):t.nodeType?w.grep(e,function(e){return e===t!==n}):"string"!=typeof t?w.grep(e,function(e){return u.call(t,e)>-1!==n}):w.filter(t,e,n)}w.filter=function(e,t,n){var r=t[0];return n&&(e=":not("+e+")"),1===t.length&&1===r.nodeType?w.find.matchesSelector(r,e)?[r]:[]:w.find.matches(e,w.grep(t,function(e){return 1===e.nodeType}))},w.fn.extend({find:function(e){var t,n,r=this.length,i=this;if("string"!=typeof e)return this.pushStack(w(e).filter(function(){for(t=0;t1?w.uniqueSort(n):n},filter:function(e){return this.pushStack(j(this,e||[],!1))},not:function(e){return this.pushStack(j(this,e||[],!0))},is:function(e){return!!j(this,"string"==typeof e&&D.test(e)?w(e):e||[],!1).length}});var q,L=/^(?:\s*(<[\w\W]+>)[^>]*|#([\w-]+))$/;(w.fn.init=function(e,t,n){var i,o;if(!e)return this;if(n=n||q,"string"==typeof e){if(!(i="<"===e[0]&&">"===e[e.length-1]&&e.length>=3?[null,e,null]:L.exec(e))||!i[1]&&t)return!t||t.jquery?(t||n).find(e):this.constructor(t).find(e);if(i[1]){if(t=t instanceof w?t[0]:t,w.merge(this,w.parseHTML(i[1],t&&t.nodeType?t.ownerDocument||t:r,!0)),A.test(i[1])&&w.isPlainObject(t))for(i in t)g(this[i])?this[i](t[i]):this.attr(i,t[i]);return this}return(o=r.getElementById(i[2]))&&(this[0]=o,this.length=1),this}return e.nodeType?(this[0]=e,this.length=1,this):g(e)?void 0!==n.ready?n.ready(e):e(w):w.makeArray(e,this)}).prototype=w.fn,q=w(r);var H=/^(?:parents|prev(?:Until|All))/,O={children:!0,contents:!0,next:!0,prev:!0};w.fn.extend({has:function(e){var t=w(e,this),n=t.length;return this.filter(function(){for(var e=0;e-1:1===n.nodeType&&w.find.matchesSelector(n,e))){o.push(n);break}return this.pushStack(o.length>1?w.uniqueSort(o):o)},index:function(e){return e?"string"==typeof e?u.call(w(e),this[0]):u.call(this,e.jquery?e[0]:e):this[0]&&this[0].parentNode?this.first().prevAll().length:-1},add:function(e,t){return this.pushStack(w.uniqueSort(w.merge(this.get(),w(e,t))))},addBack:function(e){return this.add(null==e?this.prevObject:this.prevObject.filter(e))}});function P(e,t){while((e=e[t])&&1!==e.nodeType);return e}w.each({parent:function(e){var t=e.parentNode;return t&&11!==t.nodeType?t:null},parents:function(e){return k(e,"parentNode")},parentsUntil:function(e,t,n){return k(e,"parentNode",n)},next:function(e){return P(e,"nextSibling")},prev:function(e){return P(e,"previousSibling")},nextAll:function(e){return k(e,"nextSibling")},prevAll:function(e){return k(e,"previousSibling")},nextUntil:function(e,t,n){return k(e,"nextSibling",n)},prevUntil:function(e,t,n){return k(e,"previousSibling",n)},siblings:function(e){return S((e.parentNode||{}).firstChild,e)},children:function(e){return S(e.firstChild)},contents:function(e){return N(e,"iframe")?e.contentDocument:(N(e,"template")&&(e=e.content||e),w.merge([],e.childNodes))}},function(e,t){w.fn[e]=function(n,r){var i=w.map(this,t,n);return"Until"!==e.slice(-5)&&(r=n),r&&"string"==typeof r&&(i=w.filter(r,i)),this.length>1&&(O[e]||w.uniqueSort(i),H.test(e)&&i.reverse()),this.pushStack(i)}});var M=/[^\x20\t\r\n\f]+/g;function R(e){var t={};return w.each(e.match(M)||[],function(e,n){t[n]=!0}),t}w.Callbacks=function(e){e="string"==typeof e?R(e):w.extend({},e);var t,n,r,i,o=[],a=[],s=-1,u=function(){for(i=i||e.once,r=t=!0;a.length;s=-1){n=a.shift();while(++s-1)o.splice(n,1),n<=s&&s--}),this},has:function(e){return e?w.inArray(e,o)>-1:o.length>0},empty:function(){return o&&(o=[]),this},disable:function(){return i=a=[],o=n="",this},disabled:function(){return!o},lock:function(){return i=a=[],n||t||(o=n=""),this},locked:function(){return!!i},fireWith:function(e,n){return i||(n=[e,(n=n||[]).slice?n.slice():n],a.push(n),t||u()),this},fire:function(){return l.fireWith(this,arguments),this},fired:function(){return!!r}};return l};function I(e){return e}function W(e){throw e}function $(e,t,n,r){var i;try{e&&g(i=e.promise)?i.call(e).done(t).fail(n):e&&g(i=e.then)?i.call(e,t,n):t.apply(void 0,[e].slice(r))}catch(e){n.apply(void 0,[e])}}w.extend({Deferred:function(t){var n=[["notify","progress",w.Callbacks("memory"),w.Callbacks("memory"),2],["resolve","done",w.Callbacks("once memory"),w.Callbacks("once memory"),0,"resolved"],["reject","fail",w.Callbacks("once memory"),w.Callbacks("once memory"),1,"rejected"]],r="pending",i={state:function(){return r},always:function(){return o.done(arguments).fail(arguments),this},"catch":function(e){return i.then(null,e)},pipe:function(){var e=arguments;return w.Deferred(function(t){w.each(n,function(n,r){var i=g(e[r[4]])&&e[r[4]];o[r[1]](function(){var e=i&&i.apply(this,arguments);e&&g(e.promise)?e.promise().progress(t.notify).done(t.resolve).fail(t.reject):t[r[0]+"With"](this,i?[e]:arguments)})}),e=null}).promise()},then:function(t,r,i){var o=0;function a(t,n,r,i){return function(){var s=this,u=arguments,l=function(){var e,l;if(!(t=o&&(r!==W&&(s=void 0,u=[e]),n.rejectWith(s,u))}};t?c():(w.Deferred.getStackHook&&(c.stackTrace=w.Deferred.getStackHook()),e.setTimeout(c))}}return w.Deferred(function(e){n[0][3].add(a(0,e,g(i)?i:I,e.notifyWith)),n[1][3].add(a(0,e,g(t)?t:I)),n[2][3].add(a(0,e,g(r)?r:W))}).promise()},promise:function(e){return null!=e?w.extend(e,i):i}},o={};return w.each(n,function(e,t){var a=t[2],s=t[5];i[t[1]]=a.add,s&&a.add(function(){r=s},n[3-e][2].disable,n[3-e][3].disable,n[0][2].lock,n[0][3].lock),a.add(t[3].fire),o[t[0]]=function(){return o[t[0]+"With"](this===o?void 0:this,arguments),this},o[t[0]+"With"]=a.fireWith}),i.promise(o),t&&t.call(o,o),o},when:function(e){var t=arguments.length,n=t,r=Array(n),i=o.call(arguments),a=w.Deferred(),s=function(e){return function(n){r[e]=this,i[e]=arguments.length>1?o.call(arguments):n,--t||a.resolveWith(r,i)}};if(t<=1&&($(e,a.done(s(n)).resolve,a.reject,!t),"pending"===a.state()||g(i[n]&&i[n].then)))return a.then();while(n--)$(i[n],s(n),a.reject);return a.promise()}});var B=/^(Eval|Internal|Range|Reference|Syntax|Type|URI)Error$/;w.Deferred.exceptionHook=function(t,n){e.console&&e.console.warn&&t&&B.test(t.name)&&e.console.warn("jQuery.Deferred exception: "+t.message,t.stack,n)},w.readyException=function(t){e.setTimeout(function(){throw t})};var F=w.Deferred();w.fn.ready=function(e){return F.then(e)["catch"](function(e){w.readyException(e)}),this},w.extend({isReady:!1,readyWait:1,ready:function(e){(!0===e?--w.readyWait:w.isReady)||(w.isReady=!0,!0!==e&&--w.readyWait>0||F.resolveWith(r,[w]))}}),w.ready.then=F.then;function _(){r.removeEventListener("DOMContentLoaded",_),e.removeEventListener("load",_),w.ready()}"complete"===r.readyState||"loading"!==r.readyState&&!r.documentElement.doScroll?e.setTimeout(w.ready):(r.addEventListener("DOMContentLoaded",_),e.addEventListener("load",_));var z=function(e,t,n,r,i,o,a){var s=0,u=e.length,l=null==n;if("object"===x(n)){i=!0;for(s in n)z(e,t,s,n[s],!0,o,a)}else if(void 0!==r&&(i=!0,g(r)||(a=!0),l&&(a?(t.call(e,r),t=null):(l=t,t=function(e,t,n){return l.call(w(e),n)})),t))for(;s1,null,!0)},removeData:function(e){return this.each(function(){K.remove(this,e)})}}),w.extend({queue:function(e,t,n){var r;if(e)return t=(t||"fx")+"queue",r=J.get(e,t),n&&(!r||Array.isArray(n)?r=J.access(e,t,w.makeArray(n)):r.push(n)),r||[]},dequeue:function(e,t){t=t||"fx";var n=w.queue(e,t),r=n.length,i=n.shift(),o=w._queueHooks(e,t),a=function(){w.dequeue(e,t)};"inprogress"===i&&(i=n.shift(),r--),i&&("fx"===t&&n.unshift("inprogress"),delete o.stop,i.call(e,a,o)),!r&&o&&o.empty.fire()},_queueHooks:function(e,t){var n=t+"queueHooks";return J.get(e,n)||J.access(e,n,{empty:w.Callbacks("once memory").add(function(){J.remove(e,[t+"queue",n])})})}}),w.fn.extend({queue:function(e,t){var n=2;return"string"!=typeof e&&(t=e,e="fx",n--),arguments.length\x20\t\r\n\f]+)/i,he=/^$|^module$|\/(?:java|ecma)script/i,ge={option:[1,""],thead:[1,"","
"],col:[2,"","
"],tr:[2,"","
"],td:[3,"","
"],_default:[0,"",""]};ge.optgroup=ge.option,ge.tbody=ge.tfoot=ge.colgroup=ge.caption=ge.thead,ge.th=ge.td;function ye(e,t){var n;return n="undefined"!=typeof e.getElementsByTagName?e.getElementsByTagName(t||"*"):"undefined"!=typeof e.querySelectorAll?e.querySelectorAll(t||"*"):[],void 0===t||t&&N(e,t)?w.merge([e],n):n}function ve(e,t){for(var n=0,r=e.length;n-1)i&&i.push(o);else if(l=w.contains(o.ownerDocument,o),a=ye(f.appendChild(o),"script"),l&&ve(a),n){c=0;while(o=a[c++])he.test(o.type||"")&&n.push(o)}return f}!function(){var e=r.createDocumentFragment().appendChild(r.createElement("div")),t=r.createElement("input");t.setAttribute("type","radio"),t.setAttribute("checked","checked"),t.setAttribute("name","t"),e.appendChild(t),h.checkClone=e.cloneNode(!0).cloneNode(!0).lastChild.checked,e.innerHTML="",h.noCloneChecked=!!e.cloneNode(!0).lastChild.defaultValue}();var be=r.documentElement,we=/^key/,Te=/^(?:mouse|pointer|contextmenu|drag|drop)|click/,Ce=/^([^.]*)(?:\.(.+)|)/;function Ee(){return!0}function ke(){return!1}function Se(){try{return r.activeElement}catch(e){}}function De(e,t,n,r,i,o){var a,s;if("object"==typeof t){"string"!=typeof n&&(r=r||n,n=void 0);for(s in t)De(e,s,n,r,t[s],o);return e}if(null==r&&null==i?(i=n,r=n=void 0):null==i&&("string"==typeof n?(i=r,r=void 0):(i=r,r=n,n=void 0)),!1===i)i=ke;else if(!i)return e;return 1===o&&(a=i,(i=function(e){return w().off(e),a.apply(this,arguments)}).guid=a.guid||(a.guid=w.guid++)),e.each(function(){w.event.add(this,t,i,r,n)})}w.event={global:{},add:function(e,t,n,r,i){var o,a,s,u,l,c,f,p,d,h,g,y=J.get(e);if(y){n.handler&&(n=(o=n).handler,i=o.selector),i&&w.find.matchesSelector(be,i),n.guid||(n.guid=w.guid++),(u=y.events)||(u=y.events={}),(a=y.handle)||(a=y.handle=function(t){return"undefined"!=typeof w&&w.event.triggered!==t.type?w.event.dispatch.apply(e,arguments):void 0}),l=(t=(t||"").match(M)||[""]).length;while(l--)d=g=(s=Ce.exec(t[l])||[])[1],h=(s[2]||"").split(".").sort(),d&&(f=w.event.special[d]||{},d=(i?f.delegateType:f.bindType)||d,f=w.event.special[d]||{},c=w.extend({type:d,origType:g,data:r,handler:n,guid:n.guid,selector:i,needsContext:i&&w.expr.match.needsContext.test(i),namespace:h.join(".")},o),(p=u[d])||((p=u[d]=[]).delegateCount=0,f.setup&&!1!==f.setup.call(e,r,h,a)||e.addEventListener&&e.addEventListener(d,a)),f.add&&(f.add.call(e,c),c.handler.guid||(c.handler.guid=n.guid)),i?p.splice(p.delegateCount++,0,c):p.push(c),w.event.global[d]=!0)}},remove:function(e,t,n,r,i){var o,a,s,u,l,c,f,p,d,h,g,y=J.hasData(e)&&J.get(e);if(y&&(u=y.events)){l=(t=(t||"").match(M)||[""]).length;while(l--)if(s=Ce.exec(t[l])||[],d=g=s[1],h=(s[2]||"").split(".").sort(),d){f=w.event.special[d]||{},p=u[d=(r?f.delegateType:f.bindType)||d]||[],s=s[2]&&new RegExp("(^|\\.)"+h.join("\\.(?:.*\\.|)")+"(\\.|$)"),a=o=p.length;while(o--)c=p[o],!i&&g!==c.origType||n&&n.guid!==c.guid||s&&!s.test(c.namespace)||r&&r!==c.selector&&("**"!==r||!c.selector)||(p.splice(o,1),c.selector&&p.delegateCount--,f.remove&&f.remove.call(e,c));a&&!p.length&&(f.teardown&&!1!==f.teardown.call(e,h,y.handle)||w.removeEvent(e,d,y.handle),delete u[d])}else for(d in u)w.event.remove(e,d+t[l],n,r,!0);w.isEmptyObject(u)&&J.remove(e,"handle events")}},dispatch:function(e){var t=w.event.fix(e),n,r,i,o,a,s,u=new Array(arguments.length),l=(J.get(this,"events")||{})[t.type]||[],c=w.event.special[t.type]||{};for(u[0]=t,n=1;n=1))for(;l!==this;l=l.parentNode||this)if(1===l.nodeType&&("click"!==e.type||!0!==l.disabled)){for(o=[],a={},n=0;n-1:w.find(i,this,null,[l]).length),a[i]&&o.push(r);o.length&&s.push({elem:l,handlers:o})}return l=this,u\x20\t\r\n\f]*)[^>]*)\/>/gi,Ae=/\s*$/g;function Le(e,t){return N(e,"table")&&N(11!==t.nodeType?t:t.firstChild,"tr")?w(e).children("tbody")[0]||e:e}function He(e){return e.type=(null!==e.getAttribute("type"))+"/"+e.type,e}function Oe(e){return"true/"===(e.type||"").slice(0,5)?e.type=e.type.slice(5):e.removeAttribute("type"),e}function Pe(e,t){var n,r,i,o,a,s,u,l;if(1===t.nodeType){if(J.hasData(e)&&(o=J.access(e),a=J.set(t,o),l=o.events)){delete a.handle,a.events={};for(i in l)for(n=0,r=l[i].length;n1&&"string"==typeof y&&!h.checkClone&&je.test(y))return e.each(function(i){var o=e.eq(i);v&&(t[0]=y.call(this,i,o.html())),Re(o,t,n,r)});if(p&&(i=xe(t,e[0].ownerDocument,!1,e,r),o=i.firstChild,1===i.childNodes.length&&(i=o),o||r)){for(u=(s=w.map(ye(i,"script"),He)).length;f")},clone:function(e,t,n){var r,i,o,a,s=e.cloneNode(!0),u=w.contains(e.ownerDocument,e);if(!(h.noCloneChecked||1!==e.nodeType&&11!==e.nodeType||w.isXMLDoc(e)))for(a=ye(s),r=0,i=(o=ye(e)).length;r0&&ve(a,!u&&ye(e,"script")),s},cleanData:function(e){for(var t,n,r,i=w.event.special,o=0;void 0!==(n=e[o]);o++)if(Y(n)){if(t=n[J.expando]){if(t.events)for(r in t.events)i[r]?w.event.remove(n,r):w.removeEvent(n,r,t.handle);n[J.expando]=void 0}n[K.expando]&&(n[K.expando]=void 0)}}}),w.fn.extend({detach:function(e){return Ie(this,e,!0)},remove:function(e){return Ie(this,e)},text:function(e){return z(this,function(e){return void 0===e?w.text(this):this.empty().each(function(){1!==this.nodeType&&11!==this.nodeType&&9!==this.nodeType||(this.textContent=e)})},null,e,arguments.length)},append:function(){return Re(this,arguments,function(e){1!==this.nodeType&&11!==this.nodeType&&9!==this.nodeType||Le(this,e).appendChild(e)})},prepend:function(){return Re(this,arguments,function(e){if(1===this.nodeType||11===this.nodeType||9===this.nodeType){var t=Le(this,e);t.insertBefore(e,t.firstChild)}})},before:function(){return Re(this,arguments,function(e){this.parentNode&&this.parentNode.insertBefore(e,this)})},after:function(){return Re(this,arguments,function(e){this.parentNode&&this.parentNode.insertBefore(e,this.nextSibling)})},empty:function(){for(var e,t=0;null!=(e=this[t]);t++)1===e.nodeType&&(w.cleanData(ye(e,!1)),e.textContent="");return this},clone:function(e,t){return e=null!=e&&e,t=null==t?e:t,this.map(function(){return w.clone(this,e,t)})},html:function(e){return z(this,function(e){var t=this[0]||{},n=0,r=this.length;if(void 0===e&&1===t.nodeType)return t.innerHTML;if("string"==typeof e&&!Ae.test(e)&&!ge[(de.exec(e)||["",""])[1].toLowerCase()]){e=w.htmlPrefilter(e);try{for(;n=0&&(u+=Math.max(0,Math.ceil(e["offset"+t[0].toUpperCase()+t.slice(1)]-o-u-s-.5))),u}function et(e,t,n){var r=$e(e),i=Fe(e,t,r),o="border-box"===w.css(e,"boxSizing",!1,r),a=o;if(We.test(i)){if(!n)return i;i="auto"}return a=a&&(h.boxSizingReliable()||i===e.style[t]),("auto"===i||!parseFloat(i)&&"inline"===w.css(e,"display",!1,r))&&(i=e["offset"+t[0].toUpperCase()+t.slice(1)],a=!0),(i=parseFloat(i)||0)+Ze(e,t,n||(o?"border":"content"),a,r,i)+"px"}w.extend({cssHooks:{opacity:{get:function(e,t){if(t){var n=Fe(e,"opacity");return""===n?"1":n}}}},cssNumber:{animationIterationCount:!0,columnCount:!0,fillOpacity:!0,flexGrow:!0,flexShrink:!0,fontWeight:!0,lineHeight:!0,opacity:!0,order:!0,orphans:!0,widows:!0,zIndex:!0,zoom:!0},cssProps:{},style:function(e,t,n,r){if(e&&3!==e.nodeType&&8!==e.nodeType&&e.style){var i,o,a,s=G(t),u=Xe.test(t),l=e.style;if(u||(t=Je(s)),a=w.cssHooks[t]||w.cssHooks[s],void 0===n)return a&&"get"in a&&void 0!==(i=a.get(e,!1,r))?i:l[t];"string"==(o=typeof n)&&(i=ie.exec(n))&&i[1]&&(n=ue(e,t,i),o="number"),null!=n&&n===n&&("number"===o&&(n+=i&&i[3]||(w.cssNumber[s]?"":"px")),h.clearCloneStyle||""!==n||0!==t.indexOf("background")||(l[t]="inherit"),a&&"set"in a&&void 0===(n=a.set(e,n,r))||(u?l.setProperty(t,n):l[t]=n))}},css:function(e,t,n,r){var i,o,a,s=G(t);return Xe.test(t)||(t=Je(s)),(a=w.cssHooks[t]||w.cssHooks[s])&&"get"in a&&(i=a.get(e,!0,n)),void 0===i&&(i=Fe(e,t,r)),"normal"===i&&t in Ve&&(i=Ve[t]),""===n||n?(o=parseFloat(i),!0===n||isFinite(o)?o||0:i):i}}),w.each(["height","width"],function(e,t){w.cssHooks[t]={get:function(e,n,r){if(n)return!ze.test(w.css(e,"display"))||e.getClientRects().length&&e.getBoundingClientRect().width?et(e,t,r):se(e,Ue,function(){return et(e,t,r)})},set:function(e,n,r){var i,o=$e(e),a="border-box"===w.css(e,"boxSizing",!1,o),s=r&&Ze(e,t,r,a,o);return a&&h.scrollboxSize()===o.position&&(s-=Math.ceil(e["offset"+t[0].toUpperCase()+t.slice(1)]-parseFloat(o[t])-Ze(e,t,"border",!1,o)-.5)),s&&(i=ie.exec(n))&&"px"!==(i[3]||"px")&&(e.style[t]=n,n=w.css(e,t)),Ke(e,n,s)}}}),w.cssHooks.marginLeft=_e(h.reliableMarginLeft,function(e,t){if(t)return(parseFloat(Fe(e,"marginLeft"))||e.getBoundingClientRect().left-se(e,{marginLeft:0},function(){return e.getBoundingClientRect().left}))+"px"}),w.each({margin:"",padding:"",border:"Width"},function(e,t){w.cssHooks[e+t]={expand:function(n){for(var r=0,i={},o="string"==typeof n?n.split(" "):[n];r<4;r++)i[e+oe[r]+t]=o[r]||o[r-2]||o[0];return i}},"margin"!==e&&(w.cssHooks[e+t].set=Ke)}),w.fn.extend({css:function(e,t){return z(this,function(e,t,n){var r,i,o={},a=0;if(Array.isArray(t)){for(r=$e(e),i=t.length;a1)}});function tt(e,t,n,r,i){return new tt.prototype.init(e,t,n,r,i)}w.Tween=tt,tt.prototype={constructor:tt,init:function(e,t,n,r,i,o){this.elem=e,this.prop=n,this.easing=i||w.easing._default,this.options=t,this.start=this.now=this.cur(),this.end=r,this.unit=o||(w.cssNumber[n]?"":"px")},cur:function(){var e=tt.propHooks[this.prop];return e&&e.get?e.get(this):tt.propHooks._default.get(this)},run:function(e){var t,n=tt.propHooks[this.prop];return this.options.duration?this.pos=t=w.easing[this.easing](e,this.options.duration*e,0,1,this.options.duration):this.pos=t=e,this.now=(this.end-this.start)*t+this.start,this.options.step&&this.options.step.call(this.elem,this.now,this),n&&n.set?n.set(this):tt.propHooks._default.set(this),this}},tt.prototype.init.prototype=tt.prototype,tt.propHooks={_default:{get:function(e){var t;return 1!==e.elem.nodeType||null!=e.elem[e.prop]&&null==e.elem.style[e.prop]?e.elem[e.prop]:(t=w.css(e.elem,e.prop,""))&&"auto"!==t?t:0},set:function(e){w.fx.step[e.prop]?w.fx.step[e.prop](e):1!==e.elem.nodeType||null==e.elem.style[w.cssProps[e.prop]]&&!w.cssHooks[e.prop]?e.elem[e.prop]=e.now:w.style(e.elem,e.prop,e.now+e.unit)}}},tt.propHooks.scrollTop=tt.propHooks.scrollLeft={set:function(e){e.elem.nodeType&&e.elem.parentNode&&(e.elem[e.prop]=e.now)}},w.easing={linear:function(e){return e},swing:function(e){return.5-Math.cos(e*Math.PI)/2},_default:"swing"},w.fx=tt.prototype.init,w.fx.step={};var nt,rt,it=/^(?:toggle|show|hide)$/,ot=/queueHooks$/;function at(){rt&&(!1===r.hidden&&e.requestAnimationFrame?e.requestAnimationFrame(at):e.setTimeout(at,w.fx.interval),w.fx.tick())}function st(){return e.setTimeout(function(){nt=void 0}),nt=Date.now()}function ut(e,t){var n,r=0,i={height:e};for(t=t?1:0;r<4;r+=2-t)i["margin"+(n=oe[r])]=i["padding"+n]=e;return t&&(i.opacity=i.width=e),i}function lt(e,t,n){for(var r,i=(pt.tweeners[t]||[]).concat(pt.tweeners["*"]),o=0,a=i.length;o1)},removeAttr:function(e){return this.each(function(){w.removeAttr(this,e)})}}),w.extend({attr:function(e,t,n){var r,i,o=e.nodeType;if(3!==o&&8!==o&&2!==o)return"undefined"==typeof e.getAttribute?w.prop(e,t,n):(1===o&&w.isXMLDoc(e)||(i=w.attrHooks[t.toLowerCase()]||(w.expr.match.bool.test(t)?dt:void 0)),void 0!==n?null===n?void w.removeAttr(e,t):i&&"set"in i&&void 0!==(r=i.set(e,n,t))?r:(e.setAttribute(t,n+""),n):i&&"get"in i&&null!==(r=i.get(e,t))?r:null==(r=w.find.attr(e,t))?void 0:r)},attrHooks:{type:{set:function(e,t){if(!h.radioValue&&"radio"===t&&N(e,"input")){var n=e.value;return e.setAttribute("type",t),n&&(e.value=n),t}}}},removeAttr:function(e,t){var n,r=0,i=t&&t.match(M);if(i&&1===e.nodeType)while(n=i[r++])e.removeAttribute(n)}}),dt={set:function(e,t,n){return!1===t?w.removeAttr(e,n):e.setAttribute(n,n),n}},w.each(w.expr.match.bool.source.match(/\w+/g),function(e,t){var n=ht[t]||w.find.attr;ht[t]=function(e,t,r){var i,o,a=t.toLowerCase();return r||(o=ht[a],ht[a]=i,i=null!=n(e,t,r)?a:null,ht[a]=o),i}});var gt=/^(?:input|select|textarea|button)$/i,yt=/^(?:a|area)$/i;w.fn.extend({prop:function(e,t){return z(this,w.prop,e,t,arguments.length>1)},removeProp:function(e){return this.each(function(){delete this[w.propFix[e]||e]})}}),w.extend({prop:function(e,t,n){var r,i,o=e.nodeType;if(3!==o&&8!==o&&2!==o)return 1===o&&w.isXMLDoc(e)||(t=w.propFix[t]||t,i=w.propHooks[t]),void 0!==n?i&&"set"in i&&void 0!==(r=i.set(e,n,t))?r:e[t]=n:i&&"get"in i&&null!==(r=i.get(e,t))?r:e[t]},propHooks:{tabIndex:{get:function(e){var t=w.find.attr(e,"tabindex");return t?parseInt(t,10):gt.test(e.nodeName)||yt.test(e.nodeName)&&e.href?0:-1}}},propFix:{"for":"htmlFor","class":"className"}}),h.optSelected||(w.propHooks.selected={get:function(e){var t=e.parentNode;return t&&t.parentNode&&t.parentNode.selectedIndex,null},set:function(e){var t=e.parentNode;t&&(t.selectedIndex,t.parentNode&&t.parentNode.selectedIndex)}}),w.each(["tabIndex","readOnly","maxLength","cellSpacing","cellPadding","rowSpan","colSpan","useMap","frameBorder","contentEditable"],function(){w.propFix[this.toLowerCase()]=this});function vt(e){return(e.match(M)||[]).join(" ")}function mt(e){return e.getAttribute&&e.getAttribute("class")||""}function xt(e){return Array.isArray(e)?e:"string"==typeof e?e.match(M)||[]:[]}w.fn.extend({addClass:function(e){var t,n,r,i,o,a,s,u=0;if(g(e))return this.each(function(t){w(this).addClass(e.call(this,t,mt(this)))});if((t=xt(e)).length)while(n=this[u++])if(i=mt(n),r=1===n.nodeType&&" "+vt(i)+" "){a=0;while(o=t[a++])r.indexOf(" "+o+" ")<0&&(r+=o+" ");i!==(s=vt(r))&&n.setAttribute("class",s)}return this},removeClass:function(e){var t,n,r,i,o,a,s,u=0;if(g(e))return this.each(function(t){w(this).removeClass(e.call(this,t,mt(this)))});if(!arguments.length)return this.attr("class","");if((t=xt(e)).length)while(n=this[u++])if(i=mt(n),r=1===n.nodeType&&" "+vt(i)+" "){a=0;while(o=t[a++])while(r.indexOf(" "+o+" ")>-1)r=r.replace(" "+o+" "," ");i!==(s=vt(r))&&n.setAttribute("class",s)}return this},toggleClass:function(e,t){var n=typeof e,r="string"===n||Array.isArray(e);return"boolean"==typeof t&&r?t?this.addClass(e):this.removeClass(e):g(e)?this.each(function(n){w(this).toggleClass(e.call(this,n,mt(this),t),t)}):this.each(function(){var t,i,o,a;if(r){i=0,o=w(this),a=xt(e);while(t=a[i++])o.hasClass(t)?o.removeClass(t):o.addClass(t)}else void 0!==e&&"boolean"!==n||((t=mt(this))&&J.set(this,"__className__",t),this.setAttribute&&this.setAttribute("class",t||!1===e?"":J.get(this,"__className__")||""))})},hasClass:function(e){var t,n,r=0;t=" "+e+" ";while(n=this[r++])if(1===n.nodeType&&(" "+vt(mt(n))+" ").indexOf(t)>-1)return!0;return!1}});var bt=/\r/g;w.fn.extend({val:function(e){var t,n,r,i=this[0];{if(arguments.length)return r=g(e),this.each(function(n){var i;1===this.nodeType&&(null==(i=r?e.call(this,n,w(this).val()):e)?i="":"number"==typeof i?i+="":Array.isArray(i)&&(i=w.map(i,function(e){return null==e?"":e+""})),(t=w.valHooks[this.type]||w.valHooks[this.nodeName.toLowerCase()])&&"set"in t&&void 0!==t.set(this,i,"value")||(this.value=i))});if(i)return(t=w.valHooks[i.type]||w.valHooks[i.nodeName.toLowerCase()])&&"get"in t&&void 0!==(n=t.get(i,"value"))?n:"string"==typeof(n=i.value)?n.replace(bt,""):null==n?"":n}}}),w.extend({valHooks:{option:{get:function(e){var t=w.find.attr(e,"value");return null!=t?t:vt(w.text(e))}},select:{get:function(e){var t,n,r,i=e.options,o=e.selectedIndex,a="select-one"===e.type,s=a?null:[],u=a?o+1:i.length;for(r=o<0?u:a?o:0;r-1)&&(n=!0);return n||(e.selectedIndex=-1),o}}}}),w.each(["radio","checkbox"],function(){w.valHooks[this]={set:function(e,t){if(Array.isArray(t))return e.checked=w.inArray(w(e).val(),t)>-1}},h.checkOn||(w.valHooks[this].get=function(e){return null===e.getAttribute("value")?"on":e.value})}),h.focusin="onfocusin"in e;var wt=/^(?:focusinfocus|focusoutblur)$/,Tt=function(e){e.stopPropagation()};w.extend(w.event,{trigger:function(t,n,i,o){var a,s,u,l,c,p,d,h,v=[i||r],m=f.call(t,"type")?t.type:t,x=f.call(t,"namespace")?t.namespace.split("."):[];if(s=h=u=i=i||r,3!==i.nodeType&&8!==i.nodeType&&!wt.test(m+w.event.triggered)&&(m.indexOf(".")>-1&&(m=(x=m.split(".")).shift(),x.sort()),c=m.indexOf(":")<0&&"on"+m,t=t[w.expando]?t:new w.Event(m,"object"==typeof t&&t),t.isTrigger=o?2:3,t.namespace=x.join("."),t.rnamespace=t.namespace?new RegExp("(^|\\.)"+x.join("\\.(?:.*\\.|)")+"(\\.|$)"):null,t.result=void 0,t.target||(t.target=i),n=null==n?[t]:w.makeArray(n,[t]),d=w.event.special[m]||{},o||!d.trigger||!1!==d.trigger.apply(i,n))){if(!o&&!d.noBubble&&!y(i)){for(l=d.delegateType||m,wt.test(l+m)||(s=s.parentNode);s;s=s.parentNode)v.push(s),u=s;u===(i.ownerDocument||r)&&v.push(u.defaultView||u.parentWindow||e)}a=0;while((s=v[a++])&&!t.isPropagationStopped())h=s,t.type=a>1?l:d.bindType||m,(p=(J.get(s,"events")||{})[t.type]&&J.get(s,"handle"))&&p.apply(s,n),(p=c&&s[c])&&p.apply&&Y(s)&&(t.result=p.apply(s,n),!1===t.result&&t.preventDefault());return t.type=m,o||t.isDefaultPrevented()||d._default&&!1!==d._default.apply(v.pop(),n)||!Y(i)||c&&g(i[m])&&!y(i)&&((u=i[c])&&(i[c]=null),w.event.triggered=m,t.isPropagationStopped()&&h.addEventListener(m,Tt),i[m](),t.isPropagationStopped()&&h.removeEventListener(m,Tt),w.event.triggered=void 0,u&&(i[c]=u)),t.result}},simulate:function(e,t,n){var r=w.extend(new w.Event,n,{type:e,isSimulated:!0});w.event.trigger(r,null,t)}}),w.fn.extend({trigger:function(e,t){return this.each(function(){w.event.trigger(e,t,this)})},triggerHandler:function(e,t){var n=this[0];if(n)return w.event.trigger(e,t,n,!0)}}),h.focusin||w.each({focus:"focusin",blur:"focusout"},function(e,t){var n=function(e){w.event.simulate(t,e.target,w.event.fix(e))};w.event.special[t]={setup:function(){var r=this.ownerDocument||this,i=J.access(r,t);i||r.addEventListener(e,n,!0),J.access(r,t,(i||0)+1)},teardown:function(){var r=this.ownerDocument||this,i=J.access(r,t)-1;i?J.access(r,t,i):(r.removeEventListener(e,n,!0),J.remove(r,t))}}});var Ct=e.location,Et=Date.now(),kt=/\?/;w.parseXML=function(t){var n;if(!t||"string"!=typeof t)return null;try{n=(new e.DOMParser).parseFromString(t,"text/xml")}catch(e){n=void 0}return n&&!n.getElementsByTagName("parsererror").length||w.error("Invalid XML: "+t),n};var St=/\[\]$/,Dt=/\r?\n/g,Nt=/^(?:submit|button|image|reset|file)$/i,At=/^(?:input|select|textarea|keygen)/i;function jt(e,t,n,r){var i;if(Array.isArray(t))w.each(t,function(t,i){n||St.test(e)?r(e,i):jt(e+"["+("object"==typeof i&&null!=i?t:"")+"]",i,n,r)});else if(n||"object"!==x(t))r(e,t);else for(i in t)jt(e+"["+i+"]",t[i],n,r)}w.param=function(e,t){var n,r=[],i=function(e,t){var n=g(t)?t():t;r[r.length]=encodeURIComponent(e)+"="+encodeURIComponent(null==n?"":n)};if(Array.isArray(e)||e.jquery&&!w.isPlainObject(e))w.each(e,function(){i(this.name,this.value)});else for(n in e)jt(n,e[n],t,i);return r.join("&")},w.fn.extend({serialize:function(){return w.param(this.serializeArray())},serializeArray:function(){return this.map(function(){var e=w.prop(this,"elements");return e?w.makeArray(e):this}).filter(function(){var e=this.type;return this.name&&!w(this).is(":disabled")&&At.test(this.nodeName)&&!Nt.test(e)&&(this.checked||!pe.test(e))}).map(function(e,t){var n=w(this).val();return null==n?null:Array.isArray(n)?w.map(n,function(e){return{name:t.name,value:e.replace(Dt,"\r\n")}}):{name:t.name,value:n.replace(Dt,"\r\n")}}).get()}});var qt=/%20/g,Lt=/#.*$/,Ht=/([?&])_=[^&]*/,Ot=/^(.*?):[ \t]*([^\r\n]*)$/gm,Pt=/^(?:about|app|app-storage|.+-extension|file|res|widget):$/,Mt=/^(?:GET|HEAD)$/,Rt=/^\/\//,It={},Wt={},$t="*/".concat("*"),Bt=r.createElement("a");Bt.href=Ct.href;function Ft(e){return function(t,n){"string"!=typeof t&&(n=t,t="*");var r,i=0,o=t.toLowerCase().match(M)||[];if(g(n))while(r=o[i++])"+"===r[0]?(r=r.slice(1)||"*",(e[r]=e[r]||[]).unshift(n)):(e[r]=e[r]||[]).push(n)}}function _t(e,t,n,r){var i={},o=e===Wt;function a(s){var u;return i[s]=!0,w.each(e[s]||[],function(e,s){var l=s(t,n,r);return"string"!=typeof l||o||i[l]?o?!(u=l):void 0:(t.dataTypes.unshift(l),a(l),!1)}),u}return a(t.dataTypes[0])||!i["*"]&&a("*")}function zt(e,t){var n,r,i=w.ajaxSettings.flatOptions||{};for(n in t)void 0!==t[n]&&((i[n]?e:r||(r={}))[n]=t[n]);return r&&w.extend(!0,e,r),e}function Xt(e,t,n){var r,i,o,a,s=e.contents,u=e.dataTypes;while("*"===u[0])u.shift(),void 0===r&&(r=e.mimeType||t.getResponseHeader("Content-Type"));if(r)for(i in s)if(s[i]&&s[i].test(r)){u.unshift(i);break}if(u[0]in n)o=u[0];else{for(i in n){if(!u[0]||e.converters[i+" "+u[0]]){o=i;break}a||(a=i)}o=o||a}if(o)return o!==u[0]&&u.unshift(o),n[o]}function Ut(e,t,n,r){var i,o,a,s,u,l={},c=e.dataTypes.slice();if(c[1])for(a in e.converters)l[a.toLowerCase()]=e.converters[a];o=c.shift();while(o)if(e.responseFields[o]&&(n[e.responseFields[o]]=t),!u&&r&&e.dataFilter&&(t=e.dataFilter(t,e.dataType)),u=o,o=c.shift())if("*"===o)o=u;else if("*"!==u&&u!==o){if(!(a=l[u+" "+o]||l["* "+o]))for(i in l)if((s=i.split(" "))[1]===o&&(a=l[u+" "+s[0]]||l["* "+s[0]])){!0===a?a=l[i]:!0!==l[i]&&(o=s[0],c.unshift(s[1]));break}if(!0!==a)if(a&&e["throws"])t=a(t);else try{t=a(t)}catch(e){return{state:"parsererror",error:a?e:"No conversion from "+u+" to "+o}}}return{state:"success",data:t}}w.extend({active:0,lastModified:{},etag:{},ajaxSettings:{url:Ct.href,type:"GET",isLocal:Pt.test(Ct.protocol),global:!0,processData:!0,async:!0,contentType:"application/x-www-form-urlencoded; charset=UTF-8",accepts:{"*":$t,text:"text/plain",html:"text/html",xml:"application/xml, text/xml",json:"application/json, text/javascript"},contents:{xml:/\bxml\b/,html:/\bhtml/,json:/\bjson\b/},responseFields:{xml:"responseXML",text:"responseText",json:"responseJSON"},converters:{"* text":String,"text html":!0,"text json":JSON.parse,"text xml":w.parseXML},flatOptions:{url:!0,context:!0}},ajaxSetup:function(e,t){return t?zt(zt(e,w.ajaxSettings),t):zt(w.ajaxSettings,e)},ajaxPrefilter:Ft(It),ajaxTransport:Ft(Wt),ajax:function(t,n){"object"==typeof t&&(n=t,t=void 0),n=n||{};var i,o,a,s,u,l,c,f,p,d,h=w.ajaxSetup({},n),g=h.context||h,y=h.context&&(g.nodeType||g.jquery)?w(g):w.event,v=w.Deferred(),m=w.Callbacks("once memory"),x=h.statusCode||{},b={},T={},C="canceled",E={readyState:0,getResponseHeader:function(e){var t;if(c){if(!s){s={};while(t=Ot.exec(a))s[t[1].toLowerCase()]=t[2]}t=s[e.toLowerCase()]}return null==t?null:t},getAllResponseHeaders:function(){return c?a:null},setRequestHeader:function(e,t){return null==c&&(e=T[e.toLowerCase()]=T[e.toLowerCase()]||e,b[e]=t),this},overrideMimeType:function(e){return null==c&&(h.mimeType=e),this},statusCode:function(e){var t;if(e)if(c)E.always(e[E.status]);else for(t in e)x[t]=[x[t],e[t]];return this},abort:function(e){var t=e||C;return i&&i.abort(t),k(0,t),this}};if(v.promise(E),h.url=((t||h.url||Ct.href)+"").replace(Rt,Ct.protocol+"//"),h.type=n.method||n.type||h.method||h.type,h.dataTypes=(h.dataType||"*").toLowerCase().match(M)||[""],null==h.crossDomain){l=r.createElement("a");try{l.href=h.url,l.href=l.href,h.crossDomain=Bt.protocol+"//"+Bt.host!=l.protocol+"//"+l.host}catch(e){h.crossDomain=!0}}if(h.data&&h.processData&&"string"!=typeof h.data&&(h.data=w.param(h.data,h.traditional)),_t(It,h,n,E),c)return E;(f=w.event&&h.global)&&0==w.active++&&w.event.trigger("ajaxStart"),h.type=h.type.toUpperCase(),h.hasContent=!Mt.test(h.type),o=h.url.replace(Lt,""),h.hasContent?h.data&&h.processData&&0===(h.contentType||"").indexOf("application/x-www-form-urlencoded")&&(h.data=h.data.replace(qt,"+")):(d=h.url.slice(o.length),h.data&&(h.processData||"string"==typeof h.data)&&(o+=(kt.test(o)?"&":"?")+h.data,delete h.data),!1===h.cache&&(o=o.replace(Ht,"$1"),d=(kt.test(o)?"&":"?")+"_="+Et+++d),h.url=o+d),h.ifModified&&(w.lastModified[o]&&E.setRequestHeader("If-Modified-Since",w.lastModified[o]),w.etag[o]&&E.setRequestHeader("If-None-Match",w.etag[o])),(h.data&&h.hasContent&&!1!==h.contentType||n.contentType)&&E.setRequestHeader("Content-Type",h.contentType),E.setRequestHeader("Accept",h.dataTypes[0]&&h.accepts[h.dataTypes[0]]?h.accepts[h.dataTypes[0]]+("*"!==h.dataTypes[0]?", "+$t+"; q=0.01":""):h.accepts["*"]);for(p in h.headers)E.setRequestHeader(p,h.headers[p]);if(h.beforeSend&&(!1===h.beforeSend.call(g,E,h)||c))return E.abort();if(C="abort",m.add(h.complete),E.done(h.success),E.fail(h.error),i=_t(Wt,h,n,E)){if(E.readyState=1,f&&y.trigger("ajaxSend",[E,h]),c)return E;h.async&&h.timeout>0&&(u=e.setTimeout(function(){E.abort("timeout")},h.timeout));try{c=!1,i.send(b,k)}catch(e){if(c)throw e;k(-1,e)}}else k(-1,"No Transport");function k(t,n,r,s){var l,p,d,b,T,C=n;c||(c=!0,u&&e.clearTimeout(u),i=void 0,a=s||"",E.readyState=t>0?4:0,l=t>=200&&t<300||304===t,r&&(b=Xt(h,E,r)),b=Ut(h,b,E,l),l?(h.ifModified&&((T=E.getResponseHeader("Last-Modified"))&&(w.lastModified[o]=T),(T=E.getResponseHeader("etag"))&&(w.etag[o]=T)),204===t||"HEAD"===h.type?C="nocontent":304===t?C="notmodified":(C=b.state,p=b.data,l=!(d=b.error))):(d=C,!t&&C||(C="error",t<0&&(t=0))),E.status=t,E.statusText=(n||C)+"",l?v.resolveWith(g,[p,C,E]):v.rejectWith(g,[E,C,d]),E.statusCode(x),x=void 0,f&&y.trigger(l?"ajaxSuccess":"ajaxError",[E,h,l?p:d]),m.fireWith(g,[E,C]),f&&(y.trigger("ajaxComplete",[E,h]),--w.active||w.event.trigger("ajaxStop")))}return E},getJSON:function(e,t,n){return w.get(e,t,n,"json")},getScript:function(e,t){return w.get(e,void 0,t,"script")}}),w.each(["get","post"],function(e,t){w[t]=function(e,n,r,i){return g(n)&&(i=i||r,r=n,n=void 0),w.ajax(w.extend({url:e,type:t,dataType:i,data:n,success:r},w.isPlainObject(e)&&e))}}),w._evalUrl=function(e){return w.ajax({url:e,type:"GET",dataType:"script",cache:!0,async:!1,global:!1,"throws":!0})},w.fn.extend({wrapAll:function(e){var t;return this[0]&&(g(e)&&(e=e.call(this[0])),t=w(e,this[0].ownerDocument).eq(0).clone(!0),this[0].parentNode&&t.insertBefore(this[0]),t.map(function(){var e=this;while(e.firstElementChild)e=e.firstElementChild;return e}).append(this)),this},wrapInner:function(e){return g(e)?this.each(function(t){w(this).wrapInner(e.call(this,t))}):this.each(function(){var t=w(this),n=t.contents();n.length?n.wrapAll(e):t.append(e)})},wrap:function(e){var t=g(e);return this.each(function(n){w(this).wrapAll(t?e.call(this,n):e)})},unwrap:function(e){return this.parent(e).not("body").each(function(){w(this).replaceWith(this.childNodes)}),this}}),w.expr.pseudos.hidden=function(e){return!w.expr.pseudos.visible(e)},w.expr.pseudos.visible=function(e){return!!(e.offsetWidth||e.offsetHeight||e.getClientRects().length)},w.ajaxSettings.xhr=function(){try{return new e.XMLHttpRequest}catch(e){}};var Vt={0:200,1223:204},Gt=w.ajaxSettings.xhr();h.cors=!!Gt&&"withCredentials"in Gt,h.ajax=Gt=!!Gt,w.ajaxTransport(function(t){var n,r;if(h.cors||Gt&&!t.crossDomain)return{send:function(i,o){var a,s=t.xhr();if(s.open(t.type,t.url,t.async,t.username,t.password),t.xhrFields)for(a in t.xhrFields)s[a]=t.xhrFields[a];t.mimeType&&s.overrideMimeType&&s.overrideMimeType(t.mimeType),t.crossDomain||i["X-Requested-With"]||(i["X-Requested-With"]="XMLHttpRequest");for(a in i)s.setRequestHeader(a,i[a]);n=function(e){return function(){n&&(n=r=s.onload=s.onerror=s.onabort=s.ontimeout=s.onreadystatechange=null,"abort"===e?s.abort():"error"===e?"number"!=typeof s.status?o(0,"error"):o(s.status,s.statusText):o(Vt[s.status]||s.status,s.statusText,"text"!==(s.responseType||"text")||"string"!=typeof s.responseText?{binary:s.response}:{text:s.responseText},s.getAllResponseHeaders()))}},s.onload=n(),r=s.onerror=s.ontimeout=n("error"),void 0!==s.onabort?s.onabort=r:s.onreadystatechange=function(){4===s.readyState&&e.setTimeout(function(){n&&r()})},n=n("abort");try{s.send(t.hasContent&&t.data||null)}catch(e){if(n)throw e}},abort:function(){n&&n()}}}),w.ajaxPrefilter(function(e){e.crossDomain&&(e.contents.script=!1)}),w.ajaxSetup({accepts:{script:"text/javascript, application/javascript, application/ecmascript, application/x-ecmascript"},contents:{script:/\b(?:java|ecma)script\b/},converters:{"text script":function(e){return w.globalEval(e),e}}}),w.ajaxPrefilter("script",function(e){void 0===e.cache&&(e.cache=!1),e.crossDomain&&(e.type="GET")}),w.ajaxTransport("script",function(e){if(e.crossDomain){var t,n;return{send:function(i,o){t=w("