2018-10-18 12:10:34 +02:00
//META{"name":"PluginRepo"}*//
2018-10-11 10:21:26 +02:00
2018-11-25 19:54:05 +01:00
class PluginRepo {
2018-10-11 10:21:26 +02:00
initConstructor ( ) {
this . sortings = {
sort : {
name : "Name" ,
author : "Author" ,
version : "Version" ,
description : "Description" ,
state : "Update State" ,
fav : "Favorites"
} ,
order : {
asc : "Ascending" ,
desc : "Descending"
}
} ;
2018-12-14 11:43:54 +01:00
this . loading = { is : false , timeout : null , amount : 0 } ;
2018-10-11 10:21:26 +02:00
this . grabbedPlugins = [ ] ;
this . foundPlugins = [ ] ;
this . loadedPlugins = { } ;
this . updateInterval ;
this . pluginRepoButtonMarkup =
` <button class="bd-pfbtn bd-pluginrepobutton">Plugin Repo</button> ` ;
this . settingsContextEntryMarkup =
` <div class=" ${ BDFDB . disCN . contextmenuitem } pluginrepo-item">
< span > Plugin Repo < / s p a n >
< div class = "${BDFDB.disCN.contextmenuhint}" > < / d i v >
< / d i v > ` ;
2018-11-25 19:54:05 +01:00
this . pluginRepoLoadingIconMarkup =
` <svg class="pluginrepo-loadingicon" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" version="1.1" width="40" height="30" viewBox="0 0 483 382">
< path d = "M0.000 183.023 L 0.000 366.046 46.377 366.046 L 92.754 366.046 92.754 312.629 L 92.754 259.213 127.223 259.213 C 174.433 259.213,187.432 257.146,210.766 245.926 C 311.105 197.681,301.344 41.358,195.859 7.193 C 173.603 -0.015,173.838 0.000,80.846 0.000 L 0.000 0.000 0.000 183.023 M157.615 88.195 C 193.007 97.413,198.827 152.678,166.407 171.674 C 158.993 176.019,155.494 176.398,122.807 176.398 L 92.754 176.398 92.754 131.677 L 92.754 86.957 122.807 86.957 C 146.807 86.957,153.819 87.206,157.615 88.195" stroke = "none" fill = "#7289da" fill - rule = "evenodd" > < / p a t h >
< path d = "M226.647 3.824 C 258.085 21.580,282.721 54.248,291.095 89.281 C 292.183 93.834,293.041 95.659,294.560 96.655 C 310.880 107.348,312.400 140.701,297.286 156.464 C 293.685 160.221,293.134 161.348,291.162 169.006 C 282.026 204.468,259.916 235.185,230.701 253.002 C 229.548 253.705,235.510 262.261,270.237 309.731 L 311.131 365.631 355.565 365.846 L 400.000 366.060 400.000 348.309 L 400.000 330.557 364.338 285.630 L 328.676 240.703 333.494 238.892 C 373.356 223.907,395.248 189.691,399.313 136.020 C 404.504 67.495,372.510 19.710,311.375 4.675 C 294.592 0.548,287.694 -0.000,252.482 0.000 L 219.876 0.000 226.647 3.824 M202.899 265.964 C 183.869 272.635,168.536 274.960,139.752 275.540 L 116.770 276.003 116.770 321.024 L 116.770 366.046 163.975 366.046 L 211.180 366.046 211.180 314.700 C 211.180 286.460,210.901 263.386,210.559 263.425 C 210.217 263.464,206.770 264.607,202.899 265.964" stroke = "none" fill = "#7f8186" fill - rule = "evenodd" > < / p a t h >
< / s v g > ` ;
2018-10-11 10:21:26 +02:00
this . pluginEntryMarkup =
2018-10-19 11:40:39 +02:00
` <li class="pluginEntry settings-closed ui-switch-item">
2018-10-11 10:21:26 +02:00
< div class = "bda-header" >
< span class = "bda-header-title" >
< span class = "bda-name" > < / s p a n > v < s p a n c l a s s = " b d a - v e r s i o n " > < / s p a n > b y < s p a n c l a s s = " b d a - a u t h o r " > < / s p a n >
< / s p a n >
< svg class = "favIcon" version = "1.1" xmlns = "http://www.w3.org/2000/svg" width = "20px" height = "20px" > < path fill = "none" stroke = "black" d = "M 19.542, 9.092 c 0.393 -0.383, 0.532 -0.946, 0.362 -1.468 c -0.17 -0.523 -0.613 -0.896 -1.157 -0.975 l -4.837 -0.703 c -0.206 -0.03 -0.384 -0.159 -0.476 -0.346 L 11.273, 1.217 c -0.243 -0.492 -0.736 -0.798 -1.285 -0.798 c -0.549, 0 -1.042, 0.306 -1.284, 0.798 L 6.541, 5.6 c -0.092, 0.187 -0.27, 0.316 -0.476, 0.346 L 1.228, 6.649 c -0.544, 0.079 -0.987, 0.452 -1.157, 0.975 c -0.17, 0.523 -0.031, 1.085, 0.362, 1.468 l 3.5, 3.411 c 0.149, 0.146, 0.218, 0.355, 0.182, 0.56 L 3.29, 17.88 c -0.073, 0.424, 0.038, 0.836, 0.312, 1.162 c 0.426, 0.507, 1.171, 0.661, 1.766, 0.348 l 4.326 -2.274 c 0.181 -0.095, 0.408 -0.094, 0.589, 0 l 4.326, 2.274 c 0.21, 0.111, 0.435, 0.167, 0.666, 0.167 c 0.423, 0, 0.824 -0.188, 1.099 -0.515 c 0.275 -0.325, 0.386 -0.738, 0.312 -1.162 l -0.826 -4.817 c -0.035 -0.205, 0.033 -0.414, 0.182 -0.56 L 19.542, 9.092 z" / > < / s v g >
< svg class = "gitIcon" version = "1.1" xmlns = "http://www.w3.org/2000/svg" width = "20px" height = "20px" > < g fill = "white" > < path d = "M 7.19, 16.027 c -0.139, 0.026 -0.199, 0.091 -0.182, 0.195 c 0.017, 0.104, 0.095, 0.138, 0.234, 0.104 c 0.139 -0.035, 0.199 -0.095, 0.182 -0.182 C 7.406, 16.049, 7.328, 16.01, 7.19, 16.027 z" / > < path d = "M 6.45, 16.131 c -0.138, 0 -0.208, 0.047 -0.208, 0.143 c 0, 0.112, 0.074, 0.16, 0.221, 0.143 c 0.138, 0, 0.208 -0.048, 0.208 -0.143 C 6.671, 16.162, 6.597, 16.114, 6.45, 16.131 z" / > < path d = "M 5.438, 16.092 c -0.035, 0.095, 0.022, 0.16, 0.169, 0.195 c 0.13, 0.052, 0.212, 0.026, 0.247 -0.078 c 0.026 -0.095 -0.03 -0.164 -0.169 -0.208 C 5.554, 15.967, 5.472, 15.996, 5.438, 16.092 z" / > < path d = "M 18.837, 1.097 C 18.106, 0.366, 17.226, 0, 16.196, 0 H 3.738 C 2.708, 0, 1.828, 0.366, 1.097, 1.097 C 0.366, 1.828, 0, 2.708, 0, 3.738 v 12.459 c 0, 1.03, 0.366, 1.91, 1.097, 2.641 c 0.731, 0.731, 1.612, 1.097, 2.641, 1.097 h 2.907 c 0.19, 0, 0.333 -0.007, 0.428 -0.019 c 0.095 -0.013, 0.19 -0.069, 0.285 -0.169 c 0.095 -0.099, 0.143 -0.244, 0.143 -0.435 c 0 -0.026 -0.002 -0.32 -0.007 -0.883 c -0.004 -0.562 -0.007 -1.008 -0.007 -1.337 l -0.298, 0.052 c -0.19, 0.035 -0.43, 0.05 -0.72, 0.045 c -0.29 -0.004 -0.59 -0.035 -0.902 -0.091 c -0.312 -0.056 -0.601 -0.186 -0.87 -0.389 c -0.268 -0.203 -0.458 -0.469 -0.571 -0.798 l -0.13 -0.299 c -0.086 -0.199 -0.223 -0.419 -0.409 -0.662 c -0.186 -0.242 -0.374 -0.407 -0.564 -0.493 l -0.091 -0.065 c -0.06 -0.043 -0.117 -0.095 -0.169 -0.156 c -0.052 -0.061 -0.091 -0.121 -0.117 -0.182 c -0.026 -0.061 -0.004 -0.11, 0.065 -0.149 c 0.069 -0.039, 0.195 -0.058, 0.376 -0.058 l 0.259, 0.039 c 0.173, 0.035, 0.387, 0.138, 0.642, 0.311 c 0.255, 0.173, 0.465, 0.398, 0.629, 0.675 c 0.199, 0.355, 0.439, 0.625, 0.72, 0.811 c 0.281, 0.186, 0.565, 0.279, 0.85, 0.279 s 0.532 -0.022, 0.74 -0.065 c 0.208 -0.043, 0.402 -0.108, 0.584 -0.195 c 0.078 -0.58, 0.29 -1.025, 0.636 -1.337 c -0.493 -0.052 -0.936 -0.13 -1.33 -0.234 c -0.394 -0.104 -0.8 -0.272 -1.22 -0.506 c -0.42 -0.234 -0.768 -0.523 -1.045 -0.87 c -0.277 -0.346 -0.504 -0.8 -0.681 -1.363 c -0.177 -0.562 -0.266 -1.211 -0.266 -1.947 c 0 -1.047, 0.342 -1.938, 1.025 -2.673 c -0.32 -0.787 -0.29 -1.67, 0.091 -2.647 c 0.251 -0.078, 0.623 -0.019, 1.116, 0.175 c 0.493, 0.195, 0.854, 0.361, 1.084, 0.5 c 0.229, 0.138, 0.413, 0.255, 0.552, 0.35 c 0.805 -0.225, 1.635 -0.337, 2.492 -0.337 c 0.856, 0, 1.687, 0.112, 2.492, 0.337 l 0.493 -0.311 c 0.338 -0.208, 0.735 -0.398, 1.194 -0.571 c 0.459 -0.173, 0.809 -0.221, 1.051 -0.143 c 0.389, 0.978, 0.424, 1.86, 0.104, 2.647 c 0.683, 0.735, 1.025, 1.627, 1.025, 2.673 c 0, 0.735 -0.089, 1.387 -0.266, 1.953 c -0.177, 0.567 -0.406, 1.021 -0.688, 1.363 c -0.281, 0.342 -0.632, 0.629 -1.051, 0.863 c -0.42, 0.234 -0.826, 0.402 -1.22, 0.506 c -0.394, 0.104 -0.837, 0.182 -1.33, 0.234 c 0.45, 0.389, 0.675, 1.003, 0.675, 1.843 v 3.102 c 0, 0.147, 0.021, 0.266, 0.065, 0.357 c 0.044, 0.091, 0.113, 0.153, 0.208, 0.188 c 0.096, 0.035, 0.18, 0.056, 0.253, 0.065 c 0.074, 0.009, 0.18, 0.013, 0.318, 0.013 h 2.907 c 1.029, 0, 1.91 -0.366, 2.641 -1.097 c 0.731 -0.731, 1.097 -1.612, 1.097 -2.641 V 3.738 C 19.933, 2.708, 19.568, 1.827, 18.837, 1.097 z" / > < path d = "M 3.945, 14.509 c -0.06, 0.043 -0.052, 0.112, 0.026, 0.208 c 0.087, 0.086, 0.156, 0.1, 0.208, 0.039 c 0.061 -0.043, 0.052 -0.112 -0.026 -0.208 C 4.066, 14.47, 3.997, 14.457, 3.945, 14.509 z" / > < path d = "M 3.517, 14.184 c -0.026, 0.061, 0.004, 0.113, 0.091, 0.156 c 0.069, 0.043, 0.126, 0.035, 0.169 -0.026 c 0.026 -0.061 -0.004 -0.113 -0.091 -0.156 C 3.599, 14.132, 3.543, 14.141, 3.517, 14.184 z" / > < path d = "M 4.348, 15.015 c -0.078, 0.043 -0.078, 0.121, 0, 0.234 c 0.078, 0.113, 0.151, 0.143, 0.221, 0.091 c 0.078 -0.061, 0.078 -0.143, 0 -0.247 C 4.499, 14.981, 4.425, 14.954, 4.348, 15.015 z" / > < path d = "M 4.802, 15.599 c -0.078, 0.069 -0.061, 0.151, 0.052, 0.247 c 0.104, 0.104, 0.19, 0.117, 0.259, 0.039 c 0.069 -0.069, 0.052 -0.151 -0.052 -0.246 C 4.958, 15.534, 4.871, 15.521, 4.802, 15.599 z" / > < / g > < / s v g >
< / d i v >
< div class = "bda-description-wrap ${BDFDB.disCN.scrollerwrap}" >
< div class = "bda-description ${BDFDB.disCN.scroller}" style = "display: block;" > < / d i v >
< / d i v >
< div class = "bda-footer" >
< span class = "bda-links" > < / s p a n >
< svg class = "trashIcon" version = "1.1" xmlns = "http://www.w3.org/2000/svg" width = "20px" height = "20px" > < g fill = "white" > < path d = "M 18.012, 0.648 H 12.98 C 12.944, 0.284, 12.637, 0, 12.264, 0 H 8.136 c -0.373, 0 -0.68, 0.284 -0.716, 0.648 H 2.389 c -0.398, 0 -0.72, 0.322 -0.72, 0.72 v 1.368 c 0, 0.398, 0.322, 0.72, 0.72, 0.72 h 15.623 c 0.398, 0, 0.72 -0.322, 0.72 -0.72 V 1.368 C 18.731, 0.97, 18.409, 0.648, 18.012, 0.648 z" / > < path d = "M 3.178, 4.839 v 14.841 c 0, 0.397, 0.322, 0.72, 0.72, 0.72 h 12.604 c 0.398, 0, 0.72 -0.322, 0.72 -0.72 V 4.839 H 3.178 z M 8.449, 15.978 c 0, 0.438 -0.355, 0.794 -0.794, 0.794 c -0.438, 0 -0.794 -0.355 -0.794 -0.794 V 8.109 c 0 -0.438, 0.355 -0.794, 0.794 -0.794 c 0.438, 0, 0.794, 0.355, 0.794, 0.794 V 15.978 z M 13.538, 15.978 c 0, 0.438 -0.355, 0.794 -0.794, 0.794 s -0.794 -0.355 -0.794 -0.794 V 8.109 c 0 -0.438, 0.355 -0.794, 0.794 -0.794 c 0.438, 0, 0.794, 0.355, 0.794, 0.794 V 15.978 z" / > < / g > < / s v g >
< button class = "btn-download bda-settings-button" > Download < / b u t t o n >
< / d i v >
< / l i > ` ;
this . pluginRepoModalMarkup =
` <span class="pluginrepo-modal DevilBro-modal">
< div class = "${BDFDB.disCN.backdrop}" > < / d i v >
< div class = "${BDFDB.disCN.modal}" >
< div class = "${BDFDB.disCN.modalinner}" >
< div class = "${BDFDB.disCNS.modalsub + BDFDB.disCN.modalsizelarge}" >
< div class = "${BDFDB.disCNS.flex + BDFDB.disCNS.flex2 + BDFDB.disCNS.horizontal + BDFDB.disCNS.horizontal2 + BDFDB.disCNS.directionrow + BDFDB.disCNS.justifystart + BDFDB.disCNS.aligncenter + BDFDB.disCNS.nowrap + BDFDB.disCN.modalheader}" style = "flex: 0 0 auto; padding: 20px 20px 0 20px;" >
< div class = "${BDFDB.disCN.flexchild}" style = "flex: 1 1 auto;" >
< h4 class = "${BDFDB.disCNS.h4 + BDFDB.disCNS.headertitle + BDFDB.disCNS.size16 + BDFDB.disCNS.height20 + BDFDB.disCNS.weightsemibold + BDFDB.disCNS.defaultcolor + BDFDB.disCNS.h4defaultmargin + BDFDB.disCN.marginreset} pluginAmount" > Plugin Repository < / h 4 >
< div class = "${BDFDB.disCNS.modalguildname + BDFDB.disCNS.small + BDFDB.disCNS.size12 + BDFDB.disCNS.height16 + BDFDB.disCN.primary}" > < / d i v >
< / d i v >
< svg class = "${BDFDB.disCNS.modalclose + BDFDB.disCN.flexchild}" xmlns = "http://www.w3.org/2000/svg" width = "18" height = "18" viewBox = "0 0 12 12" >
< g fill = "none" fill - rule = "evenodd" >
< path d = "M0 0h12v12H0" > < / p a t h >
< path class = "fill" fill = "currentColor" d = "M9.5 3.205L8.795 2.5 6 5.295 3.205 2.5l-.705.705L5.295 6 2.5 8.795l.705.705L6 6.705 8.795 9.5l.705-.705L6.705 6" > < / p a t h >
< / g >
< / s v g >
< / d i v >
< div class = "${BDFDB.disCNS.flex + BDFDB.disCNS.flex2 + BDFDB.disCNS.horizontal + BDFDB.disCNS.horizontal2 + BDFDB.disCNS.directionrow + BDFDB.disCNS.justifystart + BDFDB.disCNS.aligncenter + BDFDB.disCNS.nowrap + BDFDB.disCNS.modalheader + BDFDB.disCN.marginbottom20}" style = "flex: 0 0 auto; padding: 10px 20px 0px 20px;" >
< div tab = "plugins" class = "tab selected" > Plugins < / d i v >
< div tab = "settings" class = "tab" > Settings < / d i v >
< div class = "${BDFDB.disCNS.flex + BDFDB.disCNS.flex2 + BDFDB.disCNS.horizontal + BDFDB.disCNS.horizontal2 + BDFDB.disCNS.directionrow + BDFDB.disCNS.justifystart + BDFDB.disCNS.alignstretch + BDFDB.disCNS.nowrap + BDFDB.disCNS.searchbar + BDFDB.disCN.size14}" style = "flex: 1 1 auto; margin: -15px 5px 0 0;" >
< input class = "${BDFDB.disCNS.searchbarinput + BDFDB.disCN.flexchild}" value = "" placeholder = "Search for ..." style = "flex: 1 1 auto;" >
< div class = "${BDFDB.disCNS.searchbariconwrap + BDFDB.disCN.flexchild}" >
< i class = "${BDFDB.disCNS.searchbaricon + BDFDB.disCNS.searchbareyeglass + BDFDB.disCN.searchbarvisible}" / >
< i class = "${BDFDB.disCNS.searchbaricon + BDFDB.disCN.searchbarclear}" / >
< / d i v >
< / d i v >
< div class = "${BDFDB.disCNS.flex + BDFDB.disCNS.flex2 + BDFDB.disCNS.horizontal + BDFDB.disCNS.horizontal2 + BDFDB.disCNS.directionrow + BDFDB.disCNS.justifystart + BDFDB.disCNS.aligncenter + BDFDB.disCNS.nowrap + BDFDB.disCN.quickselect}" style = "padding-bottom: 15px;" >
< div class = "${BDFDB.disCN.quickselectlabel}" > Sort by : < / d i v >
< div class = "${BDFDB.disCNS.flex + BDFDB.disCNS.flex2 + BDFDB.disCNS.horizontal + BDFDB.disCNS.horizontal2 + BDFDB.disCNS.directionrow + BDFDB.disCNS.justifystart + BDFDB.disCNS.aligncenter + BDFDB.disCNS.nowrap + BDFDB.disCN.quickselectclick} sort-filter" style = "flex: 0 0 auto;" >
< div option = "${Object.keys(this.sortings.sort)[0]}" class = "${BDFDB.disCN.quickselectvalue}" > $ { this . sortings . sort [ Object . keys ( this . sortings . sort ) [ 0 ] ] } < / d i v >
< div class = "${BDFDB.disCN.quickselectarrow}" > < / d i v >
< / d i v >
< / d i v >
< div class = "${BDFDB.disCNS.flex + BDFDB.disCNS.flex2 + BDFDB.disCNS.horizontal + BDFDB.disCNS.horizontal2 + BDFDB.disCNS.directionrow + BDFDB.disCNS.justifystart + BDFDB.disCNS.aligncenter + BDFDB.disCNS.nowrap + BDFDB.disCN.quickselect}" style = "padding-bottom: 15px;" >
< div class = "${BDFDB.disCN.quickselectlabel}" > Order : < / d i v >
< div class = "${BDFDB.disCNS.flex + BDFDB.disCNS.flex2 + BDFDB.disCNS.horizontal + BDFDB.disCNS.horizontal2 + BDFDB.disCNS.directionrow + BDFDB.disCNS.justifystart + BDFDB.disCNS.aligncenter + BDFDB.disCNS.nowrap + BDFDB.disCN.quickselectclick} order-filter" style = "flex: 0 0 auto;" >
< div option = "${Object.keys(this.sortings.order)[0]}" class = "${BDFDB.disCN.quickselectvalue}" > $ { this . sortings . order [ Object . keys ( this . sortings . order ) [ 0 ] ] } < / d i v >
< div class = "${BDFDB.disCN.quickselectarrow}" > < / d i v >
< / d i v >
< / d i v >
< / d i v >
< div tab = "plugins" class = "${BDFDB.disCNS.scrollerwrap + BDFDB.disCNS.modalcontent + BDFDB.disCNS.scrollerthemed + BDFDB.disCN.themeghosthairline} tab-content" >
2018-10-21 10:41:25 +02:00
< div class = "${BDFDB.disCNS.scroller + BDFDB.disCNS.modalsubinner + BDFDB.disCN.standardsidebarview}" >
2018-10-11 10:21:26 +02:00
< ul class = "${BDFDB.disCNS.flex + BDFDB.disCNS.flex2 + BDFDB.disCNS.vertical + BDFDB.disCNS.directioncolumn + BDFDB.disCNS.justifystart + BDFDB.disCNS.alignstretch + BDFDB.disCN.nowrap} bda-slist plugins" style = "flex: 1 1 auto;" > < / u l >
< / d i v >
< / d i v >
< div tab = "settings" class = "${BDFDB.disCNS.flex + BDFDB.disCNS.flex2 + BDFDB.disCNS.vertical + BDFDB.disCNS.directioncolumn + BDFDB.disCNS.justifystart + BDFDB.disCNS.alignstretch + BDFDB.disCNS.nowrap + BDFDB.disCN.modalsubinner} tab-content" style = "flex: 1 1 auto;" >
< div class = "${BDFDB.disCNS.flex + BDFDB.disCNS.flex2 + BDFDB.disCNS.horizontal + BDFDB.disCNS.horizontal2 + BDFDB.disCNS.directionrow + BDFDB.disCNS.justifystart + BDFDB.disCNS.aligncenter + BDFDB.disCNS.nowrap + BDFDB.disCN.marginbottom20}" style = "flex: 0 0 auto;" >
2018-10-19 11:40:39 +02:00
< h3 class = "${BDFDB.disCNS.titledefault + BDFDB.disCNS.title + BDFDB.disCNS.marginreset + BDFDB.disCNS.weightmedium + BDFDB.disCNS.size16 + BDFDB.disCNS.height24 + BDFDB.disCN.flexchild}" style = "flex: 1 1 auto; width: 800px;" > To expierence PluginRepo in the best way . I would recommend you to enable BD intern reload function , that way all downloaded files are loaded into Discord without the need to reload . < / h 3 >
2018-10-11 10:21:26 +02:00
< / d i v >
< div class = "${BDFDB.disCNS.flex + BDFDB.disCNS.flex2 + BDFDB.disCNS.horizontal + BDFDB.disCNS.horizontal2 + BDFDB.disCNS.directionrow + BDFDB.disCNS.justifystart + BDFDB.disCNS.aligncenter + BDFDB.disCNS.nowrap + BDFDB.disCN.marginbottom20}" style = "flex: 0 0 auto;" >
< h3 class = "${BDFDB.disCNS.titledefault + BDFDB.disCNS.title + BDFDB.disCNS.marginreset + BDFDB.disCNS.weightmedium + BDFDB.disCNS.size16 + BDFDB.disCNS.height24 + BDFDB.disCN.flexchild}" style = "flex: 1 1 auto;" > Hide updated Plugins . < / h 3 >
< div class = "${BDFDB.disCNS.flexchild + BDFDB.disCNS.switchenabled + BDFDB.disCNS.switch + BDFDB.disCNS.switchvalue + BDFDB.disCNS.switchsizedefault + BDFDB.disCNS.switchsize + BDFDB.disCN.switchthemedefault}" style = "flex: 0 0 auto;" >
< input type = "checkbox" value = "updated" class = "${BDFDB.disCNS.switchinnerenabled + BDFDB.disCN.switchinner} hide-checkbox" id = "input-hideupdated" >
< / d i v >
< / d i v >
< div class = "${BDFDB.disCNS.flex + BDFDB.disCNS.flex2 + BDFDB.disCNS.horizontal + BDFDB.disCNS.horizontal2 + BDFDB.disCNS.directionrow + BDFDB.disCNS.justifystart + BDFDB.disCNS.aligncenter + BDFDB.disCNS.nowrap + BDFDB.disCN.marginbottom20}" style = "flex: 0 0 auto;" >
< h3 class = "${BDFDB.disCNS.titledefault + BDFDB.disCNS.title + BDFDB.disCNS.marginreset + BDFDB.disCNS.weightmedium + BDFDB.disCNS.size16 + BDFDB.disCNS.height24 + BDFDB.disCN.flexchild}" style = "flex: 1 1 auto;" > Hide outdated Plugins . < / h 3 >
< div class = "${BDFDB.disCNS.flexchild + BDFDB.disCNS.switchenabled + BDFDB.disCNS.switch + BDFDB.disCNS.switchvalue + BDFDB.disCNS.switchsizedefault + BDFDB.disCNS.switchsize + BDFDB.disCN.switchthemedefault}" style = "flex: 0 0 auto;" >
< input type = "checkbox" value = "outdated" class = "${BDFDB.disCNS.switchinnerenabled + BDFDB.disCN.switchinner} hide-checkbox" id = "input-hideoutdated" >
< / d i v >
< / d i v >
< div class = "${BDFDB.disCNS.flex + BDFDB.disCNS.flex2 + BDFDB.disCNS.horizontal + BDFDB.disCNS.horizontal2 + BDFDB.disCNS.directionrow + BDFDB.disCNS.justifystart + BDFDB.disCNS.aligncenter + BDFDB.disCNS.nowrap + BDFDB.disCN.marginbottom20}" style = "flex: 0 0 auto;" >
< h3 class = "${BDFDB.disCNS.titledefault + BDFDB.disCNS.title + BDFDB.disCNS.marginreset + BDFDB.disCNS.weightmedium + BDFDB.disCNS.size16 + BDFDB.disCNS.height24 + BDFDB.disCN.flexchild}" style = "flex: 1 1 auto;" > Hide downloadable Plugins . < / h 3 >
< div class = "${BDFDB.disCNS.flexchild + BDFDB.disCNS.switchenabled + BDFDB.disCNS.switch + BDFDB.disCNS.switchvalue + BDFDB.disCNS.switchsizedefault + BDFDB.disCNS.switchsize + BDFDB.disCN.switchthemedefault}" style = "flex: 0 0 auto;" >
< input type = "checkbox" value = "downloadable" class = "${BDFDB.disCNS.switchinnerenabled + BDFDB.disCN.switchinner} hide-checkbox" id = "input-hidedownloadable" >
< / d i v >
< / d i v >
< div id = "RNMoption" class = "${BDFDB.disCNS.flex + BDFDB.disCNS.flex2 + BDFDB.disCNS.horizontal + BDFDB.disCNS.horizontal2 + BDFDB.disCNS.directionrow + BDFDB.disCNS.justifystart + BDFDB.disCNS.aligncenter + BDFDB.disCNS.nowrap + BDFDB.disCN.marginbottom20}" style = "flex: 0 0 auto;" >
2018-10-22 19:52:10 +02:00
< h3 class = "${BDFDB.disCNS.titledefault + BDFDB.disCNS.title + BDFDB.disCNS.marginreset + BDFDB.disCNS.weightmedium + BDFDB.disCNS.size16 + BDFDB.disCNS.height24 + BDFDB.disCN.flexchild}" style = "flex: 1 1 auto;" > Start Plugin after Download ( Automatic Loading needed ) < / h 3 >
2018-10-11 10:21:26 +02:00
< div class = "${BDFDB.disCNS.flexchild + BDFDB.disCNS.switchenabled + BDFDB.disCNS.switch + BDFDB.disCNS.switchvalue + BDFDB.disCNS.switchsizedefault + BDFDB.disCNS.switchsize + BDFDB.disCN.switchthemedefault}" style = "flex: 0 0 auto;" >
< input type = "checkbox" class = "${BDFDB.disCNS.switchinnerenabled + BDFDB.disCN.switchinner}" id = "input-rnmstart" >
< / d i v >
< / d i v >
< / d i v >
< / d i v >
< / d i v >
< / d i v >
< / s p a n > ` ;
this . sortPopoutMarkup =
` <div class=" ${ BDFDB . disCNS . popout + BDFDB . disCNS . popoutbottomright + BDFDB . disCN . popoutnoshadow } pluginrepo-sort-popout" style="position: fixed; z-index: 1100; visibility: visible; transform: translateX(-100%) translateY(0%) translateZ(0px);">
< div >
< div class = "${BDFDB.disCN.contextmenu} quickSelectPopout" >
< div class = "${BDFDB.disCN.contextmenuitemgroup}" >
$ { Object . keys ( this . sortings . sort ) . map ( ( key , i ) => ` <div option=" ${ key } " class=" ${ BDFDB . disCN . contextmenuitem } "> ${ this . sortings . sort [ key ] } </div> ` ) . join ( "" ) }
< / d i v >
< / d i v >
< / d i v >
< / d i v > ` ;
this . orderPopoutMarkup =
` <div class=" ${ BDFDB . disCNS . popout + BDFDB . disCNS . popoutbottomright + BDFDB . disCN . popoutnoshadow } pluginrepo-order-popout" style="position: fixed; z-index: 1100; visibility: visible; transform: translateX(-100%) translateY(0%) translateZ(0px);">
< div >
< div class = "${BDFDB.disCN.contextmenu} quickSelectPopout" >
< div class = "${BDFDB.disCN.contextmenuitemgroup}" >
$ { Object . keys ( this . sortings . order ) . map ( ( key , i ) => ` <div option=" ${ key } " class=" ${ BDFDB . disCN . contextmenuitem } "> ${ this . sortings . order [ key ] } </div> ` ) . join ( "" ) }
< / d i v >
< / d i v >
< / d i v >
< / d i v > ` ;
this . css = `
2018-11-25 19:54:05 +01:00
$ { BDFDB . dotCN . app } > . repo - loadingwrapper {
position : absolute ;
bottom : 0 ;
right : 0 ;
z - index : 1000 ;
animation : repo - loadingwrapper - fade 3 s infinite ease ;
}
@ keyframes repo - loadingwrapper - fade {
from { opacity : 0.1 ; }
50 % { opacity : 0.9 ; }
to { opacity : 0.1 ; }
}
2018-10-11 10:21:26 +02:00
. pluginrepo - modal $ { BDFDB . dotCN . modalinner } {
min - height : 100 % ;
}
2018-10-19 11:40:39 +02:00
. pluginrepo - modal . pluginEntry {
2018-10-11 10:21:26 +02:00
overflow : visible ! important ;
}
. pluginrepo - modal . pluginEntry . gitIcon ,
. pluginrepo - modal . pluginEntry . favIcon ,
. pluginrepo - modal . pluginEntry . trashIcon {
margin - right : 5 px ;
cursor : pointer ;
}
. pluginrepo - modal . pluginEntry . trashIcon ,
. pluginrepo - modal . pluginEntry . favIcon {
margin - left : auto ;
}
. pluginrepo - modal . pluginEntry . btn - download {
margin - left : 0 ! important ;
}
. pluginrepo - modal . pluginEntry . favIcon path {
stroke : yellow ;
fill : none ;
}
. pluginrepo - modal . pluginEntry . favIcon . favorized path {
stroke : yellow ;
fill : yellow ;
}
. pluginrepo - modal . pluginEntry . downloadable . trashIcon {
display : none ;
}
. pluginrepo - modal . pluginEntry . downloadable . btn - download {
background - color : rgb ( 114 , 137 , 218 ) ! important ;
margin - left : auto ! important ;
}
. pluginrepo - modal . pluginEntry . outdated . btn - download {
background - color : rgb ( 240 , 71 , 71 ) ! important ;
margin - left : 0 ! important ;
}
. pluginrepo - modal . pluginEntry . updated . btn - download {
background - color : rgb ( 67 , 181 , 129 ) ! important ;
margin - left : 0 ! important ;
}
. pluginrepo - trashicon - tooltip {
z - index : 3500 ! important ;
}
. pluginrepo - modal . pluginEntry . jiiks . bda - right {
flex : 1 1 auto ;
}
. pluginrepo - modal . pluginEntry . jiiks . bda - header ,
. pluginrepo - modal . pluginEntry . jiiks . bda - footer {
display : flex ;
align - items : center ;
margin : 0 ! important ;
}
. pluginrepo - modal . pluginEntry . jiiks . bda - footer {
margin - top : 33 % ! important ;
} ` ;
}
getName ( ) { return "PluginRepo" ; }
getDescription ( ) { return "Allows you to look at all plugins from the plugin repo and download them on the fly. Repo button is in the plugins settings." ; }
2018-12-14 11:43:54 +01:00
getVersion ( ) { return "1.6.3" ; }
2018-10-11 10:21:26 +02:00
getAuthor ( ) { return "DevilBro" ; }
getSettingsPanel ( ) {
if ( ! this . started || typeof BDFDB !== "object" ) return ;
var settingshtml = ` <div class=" ${ this . getName ( ) } -settings DevilBro-settings"><div class=" ${ BDFDB . disCNS . titledefault + BDFDB . disCNS . title + BDFDB . disCNS . size18 + BDFDB . disCNS . height24 + BDFDB . disCNS . weightnormal + BDFDB . disCN . marginbottom8 } "> ${ this . getName ( ) } </div><div class="DevilBro-settings-inner"> ` ;
settingshtml += ` <div class=" ${ BDFDB . disCNS . flex + BDFDB . disCNS . flex2 + BDFDB . disCNS . horizontal + BDFDB . disCNS . horizontal2 + BDFDB . disCNS . directionrow + BDFDB . disCNS . justifystart + BDFDB . disCNS . aligncenter + BDFDB . disCNS . nowrap + BDFDB . disCN . marginbottom8 } " style="flex: 0 0 auto;"><h3 class=" ${ BDFDB . disCNS . titledefault + BDFDB . disCNS . title + BDFDB . disCNS . marginreset + BDFDB . disCNS . weightmedium + BDFDB . disCNS . size16 + BDFDB . disCNS . height24 + BDFDB . disCN . flexchild } " style="flex: 0 0 auto;">Add Plugin:</h3><input type="text" placeholder="Insert Raw Github Link of Plugin (https://raw.githubusercontent.com/...)" class=" ${ BDFDB . disCNS . inputdefault + BDFDB . disCNS . input + BDFDB . disCN . size16 } " id="input-pluginurl" style="flex: 1 1 auto;"><button type="button" class=" ${ BDFDB . disCNS . flexchild + BDFDB . disCNS . button + BDFDB . disCNS . buttonlookfilled + BDFDB . disCNS . buttoncolorbrand + BDFDB . disCNS . buttonsizemedium + BDFDB . disCN . buttongrow } btn-add btn-addplugin" style="flex: 0 0 auto;"><div class=" ${ BDFDB . disCN . buttoncontents } "></div></button></div> ` ;
settingshtml += ` <h3 class=" ${ BDFDB . disCNS . titledefault + BDFDB . disCNS . title + BDFDB . disCNS . marginreset + BDFDB . disCNS . weightmedium + BDFDB . disCNS . size16 + BDFDB . disCNS . height24 + BDFDB . disCN . flexchild } " style="flex: 1 1 auto;">Your additional Plugin List:</h3><div class="DevilBro-settings-inner-list plugin-list ${ BDFDB . disCN . marginbottom8 } "> ` ;
var ownlist = BDFDB . loadData ( "ownlist" , this , "ownlist" ) || [ ] ;
for ( let url of ownlist ) {
settingshtml += ` <div class=" ${ BDFDB . disCNS . flex + BDFDB . disCNS . flex2 + BDFDB . disCNS . vertical + BDFDB . disCNS . directionrow + BDFDB . disCNS . justifystart + BDFDB . disCNS . alignstretch + BDFDB . disCNS . nowrap + BDFDB . disCNS . margintop4 + BDFDB . disCNS . marginbottom4 + BDFDB . disCN . hovercard } "><div class=" ${ BDFDB . disCN . hovercardinner } "><div class=" ${ BDFDB . disCNS . description + BDFDB . disCNS . formtext + BDFDB . disCNS . note + BDFDB . disCNS . margintop4 + BDFDB . disCNS . modedefault + BDFDB . disCNS . primary + BDFDB . disCN . ellipsis } entryurl"> ${ url } </div></div><div class=" ${ BDFDB . disCN . hovercardbutton } remove-plugin"></div></div> ` ;
}
settingshtml += ` </div> ` ;
settingshtml += ` <div class=" ${ BDFDB . disCNS . flex + BDFDB . disCNS . flex2 + BDFDB . disCNS . horizontal + BDFDB . disCNS . horizontal2 + BDFDB . disCNS . directionrow + BDFDB . disCNS . justifystart + BDFDB . disCNS . aligncenter + BDFDB . disCNS . nowrap + BDFDB . disCN . marginbottom8 } " style="flex: 0 0 auto;"><h3 class=" ${ BDFDB . disCNS . titledefault + BDFDB . disCNS . title + BDFDB . disCNS . marginreset + BDFDB . disCNS . weightmedium + BDFDB . disCNS . size16 + BDFDB . disCNS . height24 + BDFDB . disCN . flexchild } " style="flex: 1 1 auto;">Force all Plugins to be fetched again.</h3><button type="button" class=" ${ BDFDB . disCNS . flexchild + BDFDB . disCNS . button + BDFDB . disCNS . buttonlookfilled + BDFDB . disCNS . buttoncolorbrand + BDFDB . disCNS . buttonsizemedium + BDFDB . disCN . buttongrow } refresh-button" style="flex: 0 0 auto;"><div class=" ${ BDFDB . disCN . buttoncontents } ">Refresh</div></button></div> ` ;
settingshtml += ` <div class=" ${ BDFDB . disCNS . flex + BDFDB . disCNS . flex2 + BDFDB . disCNS . horizontal + BDFDB . disCNS . horizontal2 + BDFDB . disCNS . directionrow + BDFDB . disCNS . justifystart + BDFDB . disCNS . aligncenter + BDFDB . disCNS . nowrap + BDFDB . disCN . marginbottom20 } " style="flex: 0 0 auto;"><h3 class=" ${ BDFDB . disCNS . titledefault + BDFDB . disCNS . title + BDFDB . disCNS . marginreset + BDFDB . disCNS . weightmedium + BDFDB . disCNS . size16 + BDFDB . disCNS . height24 + BDFDB . disCN . flexchild } " style="flex: 1 1 auto;">Remove all added Plugins from your own list.</h3><button type="button" class=" ${ BDFDB . disCNS . flexchild + BDFDB . disCNS . button + BDFDB . disCNS . buttonlookfilled + BDFDB . disCNS . buttoncolorred + BDFDB . disCNS . buttonsizemedium + BDFDB . disCN . buttongrow } remove-all" style="flex: 0 0 auto;"><div class=" ${ BDFDB . disCN . buttoncontents } ">Reset</div></button></div> ` ;
settingshtml += ` </div></div> ` ;
var settingspanel = $ ( settingshtml ) [ 0 ] ;
BDFDB . initElements ( settingspanel ) ;
$ ( settingspanel )
. on ( "click" , ".btn-addplugin" , ( ) => { this . addPluginToOwnList ( settingspanel ) ; } )
. on ( "keyup" , "#input-pluginurl" , ( e ) => { if ( e . which == 13 ) this . addPluginToOwnList ( settingspanel ) ; } )
. on ( "click" , ".remove-plugin" , ( e ) => { this . removePluginFromOwnList ( e ) ; } )
. on ( "click" , ".remove-all" , ( ) => { this . removeAllFromOwnList ( settingspanel ) ; } )
2018-12-14 11:43:54 +01:00
. on ( "click" , ".refresh-button" , ( ) => {
this . loading = { is : false , timeout : null , amount : 0 } ;
this . loadPlugins ( ) ;
} ) ;
2018-10-11 10:21:26 +02:00
return settingspanel ;
}
//legacy
load ( ) { }
start ( ) {
var libraryScript = null ;
if ( typeof BDFDB !== "object" || typeof BDFDB . isLibraryOutdated !== "function" || BDFDB . isLibraryOutdated ( ) ) {
libraryScript = document . querySelector ( 'head script[src="https://mwittrien.github.io/BetterDiscordAddons/Plugins/BDFDB.js"]' ) ;
if ( libraryScript ) libraryScript . remove ( ) ;
libraryScript = document . createElement ( "script" ) ;
libraryScript . setAttribute ( "type" , "text/javascript" ) ;
libraryScript . setAttribute ( "src" , "https://mwittrien.github.io/BetterDiscordAddons/Plugins/BDFDB.js" ) ;
document . head . appendChild ( libraryScript ) ;
}
this . startTimeout = setTimeout ( ( ) => { this . initialize ( ) ; } , 30000 ) ;
if ( typeof BDFDB === "object" && typeof BDFDB . isLibraryOutdated === "function" ) this . initialize ( ) ;
else libraryScript . addEventListener ( "load" , ( ) => { this . initialize ( ) ; } ) ;
}
initialize ( ) {
if ( typeof BDFDB === "object" ) {
BDFDB . loadMessage ( this ) ;
var observer = null ;
observer = new MutationObserver ( ( changes , _ ) => {
changes . forEach (
( change , j ) => {
if ( change . addedNodes ) {
change . addedNodes . forEach ( ( node ) => {
this . checkIfPluginsPage ( node ) ;
} ) ;
}
}
) ;
} ) ;
BDFDB . addObserver ( this , BDFDB . dotCN . layer + "[layer-id='user-settings']" , { name : "innerSettingsWindowObserver" , instance : observer } , { childList : true , subtree : true } ) ;
observer = new MutationObserver ( ( changes , _ ) => {
changes . forEach (
( change , i ) => {
if ( change . addedNodes ) {
change . addedNodes . forEach ( ( node ) => {
setImmediate ( ( ) => {
2018-11-25 19:54:05 +01:00
if ( node . tagName && node . getAttribute ( "layer-id" ) == "user-settings" ) {
2018-10-11 10:21:26 +02:00
BDFDB . addObserver ( this , node , { name : "innerSettingsWindowObserver" } , { childList : true , subtree : true } ) ;
this . checkIfPluginsPage ( node ) ;
}
} ) ;
} ) ;
}
}
) ;
} ) ;
BDFDB . addObserver ( this , BDFDB . dotCN . layers , { name : "settingsWindowObserver" , instance : observer } , { childList : true } ) ;
observer = new MutationObserver ( ( changes , _ ) => {
changes . forEach (
( change , i ) => {
if ( change . addedNodes ) {
change . addedNodes . forEach ( ( node ) => {
if ( node && node . nodeType == 1 && node . className . includes ( BDFDB . disCN . contextmenu ) ) {
this . onContextMenu ( node ) ;
}
} ) ;
}
}
) ;
} ) ;
BDFDB . addObserver ( this , BDFDB . dotCN . appmount , { name : "settingsContextObserver" , instance : observer } , { childList : true } ) ;
var settingswindow = document . querySelector ( BDFDB . dotCN . layer + "[layer-id='user-settings']" ) ;
if ( settingswindow ) this . checkIfPluginsPage ( settingswindow ) ;
this . loadPlugins ( ) ;
this . updateInterval = setInterval ( ( ) => { this . checkForNewPlugins ( ) ; } , 1000 * 60 * 30 ) ;
}
else {
console . error ( this . getName ( ) + ": Fatal Error: Could not load BD functions!" ) ;
}
}
stop ( ) {
if ( typeof BDFDB === "object" ) {
clearInterval ( this . updateInterval ) ;
2018-12-14 11:43:54 +01:00
clearTimeout ( this . loading . timeout ) ;
2018-10-11 10:21:26 +02:00
2018-11-25 22:11:03 +01:00
$ ( "webview[webview-pluginrepo], .pluginrepo-modal, .bd-pluginrepobutton, .pluginrepo-loadingicon" ) . remove ( ) ;
2018-11-25 19:54:05 +01:00
$ ( BDFDB . dotCN . app + " > .repo-loadingwrapper:empty" ) . remove ( ) ;
2018-10-11 10:21:26 +02:00
BDFDB . unloadMessage ( this ) ;
}
}
// begin of own functions
onContextMenu ( context ) {
if ( ! context || ! context . tagName || ! context . parentElement ) return ;
for ( let entry of context . querySelectorAll ( BDFDB . dotCN . contextmenuitem ) ) {
if ( entry . textContent == "BetterDiscord" ) {
let innerObserver = new MutationObserver ( ( changes , _ ) => {
changes . forEach (
( change , i ) => {
if ( change . addedNodes ) {
change . addedNodes . forEach ( ( node ) => {
if ( node && node . nodeType == 1 && node . className . includes ( BDFDB . disCN . contextmenu ) && ! node . querySelector ( ".pluginrepo-item" ) ) {
for ( let innerEntry of node . querySelectorAll ( BDFDB . dotCN . contextmenuitem ) ) {
if ( innerEntry . textContent == "Themes" ) {
$ ( this . settingsContextEntryMarkup )
. on ( "click" , ( ) => {
2018-12-14 11:43:54 +01:00
if ( ! this . loading . is ) $ ( context ) . hide ( ) ;
2018-10-11 10:21:26 +02:00
this . openPluginRepoModal ( ) ;
} )
. insertAfter ( innerEntry ) ;
$ ( node ) . css ( "top" , $ ( context ) . css ( "top" ) . replace ( "px" , "" ) - $ ( node ) . outerHeight ( ) + $ ( context ) . outerHeight ( ) ) ;
break ;
}
}
}
} ) ;
}
}
) ;
} ) ;
innerObserver . observe ( entry , { childList : true } ) ;
break ;
}
}
}
addPluginToOwnList ( settingspanel ) {
var pluginUrlInput = settingspanel . querySelector ( "#input-pluginurl" ) ;
var pluginList = settingspanel . querySelector ( ".plugin-list" ) ;
if ( pluginUrlInput && pluginList ) {
var url = pluginUrlInput . value ;
pluginUrlInput . value = null ;
var ownlist = BDFDB . loadData ( "ownlist" , this , "ownlist" ) || [ ] ;
if ( ! ownlist . includes ( url ) ) {
ownlist . push ( url ) ;
BDFDB . saveData ( "ownlist" , ownlist , this , "ownlist" ) ;
$ ( ` <div class=" ${ BDFDB . disCNS . flex + BDFDB . disCNS . flex2 + BDFDB . disCNS . vertical + BDFDB . disCNS . directionrow + BDFDB . disCNS . justifystart + BDFDB . disCNS . alignstretch + BDFDB . disCNS . nowrap + BDFDB . disCNS . margintop4 + BDFDB . disCNS . marginbottom4 + BDFDB . disCN . hovercard } "><div class=" ${ BDFDB . disCN . hovercardinner } "><div class=" ${ BDFDB . disCNS . description + BDFDB . disCNS . formtext + BDFDB . disCNS . note + BDFDB . disCNS . margintop4 + BDFDB . disCNS . modedefault + BDFDB . disCNS . primary + BDFDB . disCN . ellipsis } entryurl"> ${ url } </div></div><div class=" ${ BDFDB . disCN . hovercardbutton } remove-plugin"></div></div> ` ) . appendTo ( pluginList ) ;
}
}
}
removePluginFromOwnList ( e ) {
var entry = e . currentTarget . parentElement ;
var url = entry . querySelector ( ".entryurl" ) . textContent ;
entry . remove ( ) ;
var ownlist = BDFDB . loadData ( "ownlist" , this , "ownlist" ) || [ ] ;
BDFDB . removeFromArray ( ownlist , url ) ;
BDFDB . saveData ( "ownlist" , ownlist , this , "ownlist" ) ;
}
removeAllFromOwnList ( settingspanel ) {
if ( confirm ( "Are you sure you want to remove all added Plugins from your own list?" ) ) {
BDFDB . saveData ( "ownlist" , [ ] , this , "ownlist" ) ;
settingspanel . querySelectorAll ( BDFDB . dotCN . hovercard ) . forEach ( ele => { ele . remove ( ) ; } ) ;
}
}
checkIfPluginsPage ( container ) {
if ( container && container . tagName ) {
var folderbutton = container . querySelector ( ".bd-pfbtn" ) ;
if ( folderbutton ) {
var buttonbar = folderbutton . parentElement ;
if ( buttonbar && buttonbar . tagName ) {
var header = buttonbar . querySelector ( "h2" ) ;
if ( header && header . innerText . toUpperCase ( ) === "PLUGINS" ) {
this . addPluginRepoButton ( buttonbar ) ;
}
}
}
}
}
addPluginRepoButton ( container ) {
if ( container && ! container . querySelector ( ".bd-pluginrepobutton" ) ) {
$ ( container ) . find ( ".bda-description" ) . css ( "display" , "block" ) ;
$ ( this . pluginRepoButtonMarkup )
. insertAfter ( container . querySelector ( ".bd-pfbtn" ) )
. on ( "click" , ( ) => {
this . openPluginRepoModal ( )
} )
. on ( "mouseenter" , ( e ) => {
BDFDB . createTooltip ( "Open Plugin Repo" , e . currentTarget , { type : "top" , selector : "pluginrepo-button-tooltip" } ) ;
} ) ;
}
}
openPluginRepoModal ( showOnlyOutdated = false ) {
2018-12-14 11:43:54 +01:00
if ( this . loading . is ) {
2018-10-11 10:21:26 +02:00
BDFDB . showToast ( ` Plugins are still being fetched. Try again in some seconds. ` , { type : "danger" } ) ;
return ;
}
var pluginRepoModal = $ ( this . pluginRepoModalMarkup ) ;
pluginRepoModal . updateModal = true ;
pluginRepoModal . enableSearch = false ;
var hiddenSettings = BDFDB . loadAllData ( this , "hidden" ) ;
pluginRepoModal . find ( "#input-hideupdated" ) . prop ( "checked" , hiddenSettings . updated || showOnlyOutdated ) ;
pluginRepoModal . find ( "#input-hideoutdated" ) . prop ( "checked" , hiddenSettings . outdated && ! showOnlyOutdated ) ;
pluginRepoModal . find ( "#input-hidedownloadable" ) . prop ( "checked" , hiddenSettings . downloadable || showOnlyOutdated ) ;
if ( ! BDFDB . isRestartNoMoreEnabled ( ) ) pluginRepoModal . find ( "#RNMoption" ) . remove ( ) ;
else pluginRepoModal . find ( "#input-rnmstart" ) . prop ( "checked" , BDFDB . loadData ( "RNMstart" , this , "settings" ) ) ;
pluginRepoModal
. on ( "keyup." + this . getName ( ) , BDFDB . dotCN . searchbarinput , ( ) => {
clearTimeout ( pluginRepoModal . searchTimeout ) ;
pluginRepoModal . searchTimeout = setTimeout ( ( ) => { this . addPluginEntries ( pluginRepoModal ) ; } , 1000 ) ;
} )
. on ( "click." + this . getName ( ) , BDFDB . dotCN . searchbarclear + BDFDB . dotCN . searchbarvisible , ( ) => {
clearTimeout ( pluginRepoModal . searchTimeout ) ;
pluginRepoModal . searchTimeout = setTimeout ( ( ) => { this . addPluginEntries ( pluginRepoModal ) ; } , 1000 ) ;
} )
. on ( "change." + this . getName ( ) , ".hide-checkbox" , ( e ) => {
var hideButton = $ ( e . currentTarget ) ;
hiddenSettings [ hideButton . val ( ) ] = hideButton . prop ( "checked" ) ;
BDFDB . saveAllData ( hiddenSettings , this , "hidden" ) ;
} )
. on ( "change." + this . getName ( ) , "#input-rnmstart" , ( e ) => {
BDFDB . saveData ( "RNMstart" , $ ( e . currentTarget ) . prop ( "checked" ) , this , "settings" ) ;
} )
. on ( "click." + this . getName ( ) , ".sort-filter" , ( e ) => {
this . openSortPopout ( e , this . sortPopoutMarkup , pluginRepoModal ) ;
} )
. on ( "click." + this . getName ( ) , ".order-filter" , ( e ) => {
this . openSortPopout ( e , this . orderPopoutMarkup , pluginRepoModal ) ;
} )
. on ( "click." + this . getName ( ) , ".tab[tab=plugins]:not(.selected)" , ( e ) => {
this . addPluginEntries ( pluginRepoModal ) ;
} ) ;
this . createPluginEntries ( pluginRepoModal ) ;
BDFDB . appendModal ( pluginRepoModal ) ;
}
openSortPopout ( e , markup , modal ) {
var wrapper = e . currentTarget ;
if ( wrapper . classList . contains ( "popout-open" ) ) return ;
wrapper . classList . add ( "popout-open" ) ;
var value = $ ( wrapper ) . find ( BDFDB . dotCN . quickselectvalue ) ;
var popout = $ ( markup ) ;
$ ( BDFDB . dotCN . popouts ) . append ( popout )
. off ( "click" , BDFDB . dotCN . contextmenuitem )
. on ( "click" , BDFDB . dotCN . contextmenuitem , ( e2 ) => {
value . text ( $ ( e2 . currentTarget ) . text ( ) ) ;
value . attr ( "option" , $ ( e2 . currentTarget ) . attr ( "option" ) ) ;
$ ( document ) . off ( "mousedown.sortpopout" + this . getName ( ) ) ;
popout . remove ( ) ;
this . addPluginEntries ( modal ) ;
setTimeout ( ( ) => { wrapper . classList . remove ( "popout-open" ) ; } , 300 ) ;
} ) ;
popout
. css ( "left" , $ ( wrapper ) . offset ( ) . left + $ ( wrapper ) . outerWidth ( ) + "px" )
. css ( "top" , $ ( wrapper ) . offset ( ) . top + value . outerHeight ( ) + "px" )
. find ( BDFDB . dotCN . contextmenu ) . addClass ( BDFDB . getDiscordTheme ( ) ) ;
$ ( document ) . on ( "mousedown.sortpopout" + this . getName ( ) , ( e2 ) => {
if ( popout . has ( e2 . target ) . length == 0 ) {
$ ( document ) . off ( "mousedown.sortpopout" + this . getName ( ) ) ;
popout . remove ( ) ;
setTimeout ( ( ) => { wrapper . classList . remove ( "popout-open" ) ; } , 300 ) ;
}
} ) ;
}
createPluginEntries ( modal ) {
var favorites = BDFDB . loadAllData ( this , "favorites" ) ;
modal . entries = [ ] ;
for ( let url in this . loadedPlugins ) {
let plugin = this . loadedPlugins [ url ] ;
2018-10-19 11:40:39 +02:00
let div = $ ( this . pluginEntryMarkup ) ;
2018-10-11 10:21:26 +02:00
var installedPlugin = window . bdplugins [ plugin . getName ] ? window . bdplugins [ plugin . getName ] . plugin : null ;
if ( installedPlugin && installedPlugin . getAuthor ( ) . toUpperCase ( ) == plugin . getAuthor . toUpperCase ( ) ) {
if ( installedPlugin . getVersion ( ) != plugin . getVersion ) {
plugin . getState = 1 ;
div . addClass ( "outdated" )
. find ( ".btn-download" ) . text ( "Outdated" ) ;
}
else {
plugin . getState = 0 ;
div . addClass ( "updated" )
. find ( ".btn-download" ) . text ( "Updated" ) ;
}
}
else {
plugin . getState = 2 ;
div . addClass ( "downloadable" )
. find ( ".btn-download" ) . text ( "Download" ) ;
}
if ( favorites [ url ] ) {
plugin . getFav = 0 ;
div . find ( ".favIcon" ) [ 0 ] . classList . add ( "favorized" ) ;
}
else {
plugin . getFav = 1 ;
div . find ( ".favIcon" ) [ 0 ] . classList . remove ( "favorized" ) ;
}
modal . entries . push ( {
div : div ,
url : plugin . url ,
search : ( plugin . getName + " " + plugin . getVersion + " " + plugin . getAuthor + " " + plugin . getDescription ) . toUpperCase ( ) ,
name : plugin . getName ,
version : plugin . getVersion ,
author : plugin . getAuthor ,
description : plugin . getDescription ? plugin . getDescription : "No Description found." ,
fav : plugin . getFav ,
state : plugin . getState
} ) ;
}
this . addPluginEntries ( modal ) ;
}
addPluginEntries ( modal ) {
if ( typeof modal . entries != "object" ) return ;
modal . find ( ".pluginEntry" ) . remove ( ) ;
var searchstring = modal . find ( BDFDB . dotCN . searchbarinput ) . val ( ) . replace ( /[<|>]/g , "" ) . toUpperCase ( ) ;
var entries = modal . entries ;
if ( modal . find ( "#input-hideupdated" ) . prop ( "checked" ) ) entries = entries . filter ( ( entry ) => { return entry . state != 0 ? entry : null ; } ) ;
if ( modal . find ( "#input-hideoutdated" ) . prop ( "checked" ) ) entries = entries . filter ( ( entry ) => { return entry . state != 1 ? entry : null ; } ) ;
if ( modal . find ( "#input-hidedownloadable" ) . prop ( "checked" ) ) entries = entries . filter ( ( entry ) => { return entry . state != 2 ? entry : null ; } ) ;
entries = entries . filter ( ( entry ) => { return entry . search . indexOf ( searchstring ) > - 1 ? entry : null ; } ) ;
BDFDB . sortArrayByKey ( entries , modal . find ( ".sort-filter " + BDFDB . dotCN . quickselectvalue ) . attr ( "option" ) ) ;
if ( modal . find ( ".order-filter " + BDFDB . dotCN . quickselectvalue ) . attr ( "option" ) == "desc" ) entries . reverse ( ) ;
modal . find ( ".pluginAmount" ) . text ( "Plugin Repository " + entries . length + "/" + Object . keys ( this . loadedPlugins ) . length + " Plugins" ) ;
var container = modal . find ( ".plugins" ) ;
entries . forEach ( ( entry ) => {
var div = entry . div ;
var values = [ entry . name , entry . version , entry . author , entry . description ] ;
if ( searchstring . length > 0 ) {
for ( let i in values ) values [ i ] = BDFDB . highlightText ( values [ i ] , searchstring ) ;
}
2018-10-19 11:40:39 +02:00
div . find ( ".bda-name" ) . html ( values [ 0 ] ) ;
div . find ( ".bda-version" ) . html ( values [ 1 ] ) ;
div . find ( ".bda-author" ) . html ( values [ 2 ] ) ;
2018-10-11 10:21:26 +02:00
div . find ( ".bda-description" ) . html ( values [ 3 ] ) ;
div
. on ( "click." + this . getName ( ) , ".favIcon" , ( e ) => {
e . currentTarget . classList . toggle ( "favorized" ) ;
if ( e . currentTarget . classList . contains ( "favorized" ) ) {
entry . fav = 0 ;
BDFDB . saveData ( entry . url , true , this , "favorites" ) ;
}
else {
entry . fav = 1 ;
BDFDB . removeData ( entry . url , this , "favorites" ) ;
}
} )
. on ( "click." + this . getName ( ) , ".gitIcon" , ( e ) => {
var giturl = null ;
if ( entry . url . indexOf ( "https://raw.githubusercontent.com" ) == 0 ) {
var temp = entry . url . replace ( "//raw.githubusercontent" , "//github" ) . split ( "/" ) ;
temp . splice ( 5 , 0 , "blob" ) ;
giturl = temp . join ( "/" ) ;
}
else if ( entry . url . indexOf ( "https://gist.githubusercontent.com/" ) == 0 ) {
giturl = entry . url . replace ( "//gist.githubusercontent" , "//gist.github" ) . split ( "/raw/" ) [ 0 ] ;
}
if ( giturl ) {
window . open ( giturl , "_blank" ) ;
}
} )
. on ( "click." + this . getName ( ) , ".trashIcon" , ( ) => {
if ( div . hasClass ( "outdated" ) || div . hasClass ( "updated" ) ) {
entry . state = 2 ;
div . removeClass ( "outdated" ) . removeClass ( "updated" ) . addClass ( "downloadable" )
. find ( ".btn-download" ) . text ( "Download" ) ;
this . deletePluginFile ( entry ) ;
if ( ! BDFDB . isRestartNoMoreEnabled ( ) ) this . stopPlugin ( entry ) ;
}
} )
. on ( "click." + this . getName ( ) , ".btn-download" , ( ) => {
entry . state = 0 ;
div . removeClass ( "downloadable" ) . removeClass ( "outdated" ) . addClass ( "updated" )
. find ( ".btn-download" ) . text ( "Updated" ) ;
this . downloadPlugin ( entry ) ;
if ( modal . find ( "#input-rnmstart" ) . prop ( "checked" ) ) setTimeout ( ( ) => { this . startPlugin ( entry ) ; } , 3000 ) ;
} )
. on ( "mouseenter." + this . getName ( ) , ".favIcon" , ( e ) => {
BDFDB . createTooltip ( "Favorize" , e . currentTarget , { type : "top" , selector : "pluginrepo-favicon-tooltip" } ) ;
} )
. on ( "mouseenter." + this . getName ( ) , ".gitIcon" , ( e ) => {
BDFDB . createTooltip ( "Go to Git" , e . currentTarget , { type : "top" , selector : "pluginrepo-giticon-tooltip" } ) ;
} )
. on ( "mouseenter." + this . getName ( ) , ".trashIcon" , ( e ) => {
BDFDB . createTooltip ( "Delete Pluginfile" , e . currentTarget , { type : "top" , selector : "pluginrepo-trashicon-tooltip" } ) ;
} ) ;
container . append ( div ) ;
} ) ;
}
loadPlugins ( ) {
2018-11-03 18:03:47 +01:00
var getPluginInfo , createWebview , runInWebview ;
var webview , webviewrunning = false , webviewqueue = [ ] , outdated = 0 , i = 0 ;
2018-10-11 10:21:26 +02:00
var tags = [ "getName" , "getVersion" , "getAuthor" , "getDescription" ] ;
var seps = [ "\"" , "\'" , "\`" ] ;
let request = require ( "request" ) ;
request ( "https://mwittrien.github.io/BetterDiscordAddons/Plugins/PluginRepo/res/PluginList.txt" , ( error , response , result ) => {
if ( response ) {
this . loadedPlugins = { } ;
this . grabbedPlugins = result . split ( "\n" ) ;
this . foundPlugins = this . grabbedPlugins . concat ( BDFDB . loadData ( "ownlist" , this , "ownlist" ) || [ ] ) ;
2018-12-14 11:43:54 +01:00
this . loading = { is : true , timeout : setTimeout ( ( ) => {
clearTimeout ( this . loading . timeout ) ;
if ( this . started ) {
if ( this . loading . is && this . loading . amount < 4 ) setTimeout ( ( ) => { this . loadPlugins ( ) ; } , 10000 ) ;
this . loading = { is : false , timeout : null , amount : this . loading . amount } ;
}
} , 1200000 ) , amount : this . loading . amount + 1 } ;
2018-11-25 19:54:05 +01:00
var loadingiconwrapper = document . querySelector ( BDFDB . dotCN . app + "> .repo-loadingwrapper" ) ;
if ( ! loadingiconwrapper ) {
loadingiconwrapper = document . createElement ( "div" ) ;
loadingiconwrapper . className = "repo-loadingwrapper" ;
document . querySelector ( BDFDB . dotCN . app ) . appendChild ( loadingiconwrapper ) ;
}
$ ( this . pluginRepoLoadingIconMarkup )
. on ( "mouseenter." + this . getName ( ) , ( e ) => { BDFDB . createTooltip ( "Loading PluginRepo" , e . currentTarget , { type : "left" , delay : 500 } ) ; } )
. appendTo ( loadingiconwrapper ) ;
2018-11-03 21:25:45 +01:00
createWebview ( ) . then ( ( ) => {
getPluginInfo ( ( ) => {
2018-11-25 19:54:05 +01:00
if ( ! this . started ) {
2018-12-14 11:43:54 +01:00
clearTimeout ( this . loading . timeout ) ;
2018-11-25 19:54:05 +01:00
if ( typeof webview != "undefined" ) webview . remove ( ) ;
return ;
}
var finishCounter = 0 , finishInterval = setInterval ( ( ) => {
2018-12-14 11:43:54 +01:00
if ( ( webviewqueue . length == 0 && ! webviewrunning ) || finishCounter > 300 || ! this . loading . is ) {
2018-11-03 21:25:45 +01:00
clearInterval ( finishInterval ) ;
if ( typeof webview != "undefined" ) webview . remove ( ) ;
2018-11-25 19:54:05 +01:00
$ ( ".pluginrepo-loadingicon" ) . remove ( ) ;
if ( ! loadingiconwrapper . firstChild ) loadingiconwrapper . remove ( ) ;
2018-12-14 11:43:54 +01:00
clearTimeout ( this . loading . timeout ) ;
this . loading = { is : false , timeout : null , amount : this . loading . amount } ;
2018-11-03 21:25:45 +01:00
console . log ( "PluginRepo: Finished fetching Plugins." ) ;
if ( document . querySelector ( ".bd-pluginrepobutton" ) ) BDFDB . showToast ( ` Finished fetching Plugins. ` , { type : "success" } ) ;
if ( outdated > 0 ) {
var text = ` ${ outdated } of your Plugins ${ outdated == 1 ? "is" : "are" } outdated. Check: ` ;
var bar = BDFDB . createNotificationsBar ( text , { type : "danger" , btn : "PluginRepo" , selector : "pluginrepo-notice" } ) ;
2018-11-03 10:04:32 +01:00
$ ( bar ) . on ( "click." + this . getName ( ) , BDFDB . dotCN . noticebutton , ( e ) => {
2018-11-03 21:25:45 +01:00
this . openPluginRepoModal ( true ) ;
e . delegateTarget . querySelector ( BDFDB . dotCN . noticedismiss ) . click ( ) ;
2018-11-03 10:04:32 +01:00
} ) ;
}
2018-11-03 21:25:45 +01:00
if ( BDFDB . myData . id == "278543574059057154" ) {
let wrongUrls = [ ] ;
for ( let url of this . foundPlugins ) if ( url && ! this . loadedPlugins [ url ] && ! wrongUrls . includes ( url ) ) wrongUrls . push ( url ) ;
if ( wrongUrls . length > 0 ) {
var bar = BDFDB . createNotificationsBar ( ` PluginRepo: ${ wrongUrls . length } Plugin ${ wrongUrls . length > 1 ? "s" : "" } could not be loaded. ` , { type : "danger" , btn : "List" } ) ;
$ ( bar ) . on ( "click." + this . getName ( ) , BDFDB . dotCN . noticebutton , ( e ) => {
var toast = BDFDB . showToast ( wrongUrls . join ( "\n" ) , { type : "error" } ) ;
toast . style . overflow = "hidden" ;
console . log ( wrongUrls . length == 1 ? wrongUrls [ 0 ] : wrongUrls ) ;
} ) ;
}
}
2018-10-11 10:21:26 +02:00
}
2018-11-03 21:25:45 +01:00
else finishCounter ++ ;
} , 1000 ) ;
} ) ;
2018-10-11 10:21:26 +02:00
} ) ;
}
} ) ;
2018-11-03 18:03:47 +01:00
getPluginInfo = ( callback ) => {
2018-12-14 11:43:54 +01:00
if ( i >= this . foundPlugins . length || ! this . started || ! this . loading . is ) {
2018-10-11 10:21:26 +02:00
callback ( ) ;
return ;
}
let url = this . foundPlugins [ i ] . replace ( new RegExp ( "[\\r|\\n|\\t]" , "g" ) , "" ) ;
this . foundPlugins [ i ] = url ;
request ( url , ( error , response , body ) => {
2018-10-18 12:10:34 +02:00
if ( ! response ) {
if ( url && BDFDB . getAllIndexes ( this . foundPlugins , url ) . length < 2 ) this . foundPlugins . push ( url ) ;
}
2018-12-14 20:51:25 +01:00
else if ( body && body . indexOf ( "404: Not Found" ) != 0 && response . statusCode == 200 ) {
2018-10-11 10:21:26 +02:00
let plugin = { } ;
let bodycopy = body ;
if ( body . length / body . split ( "\n" ) . length > 1000 ) {
/* code is minified -> add newlines */
bodycopy = body . replace ( new RegExp ( "}" , "g" ) , "}\n" ) ;
}
2018-11-25 23:57:37 +01:00
if ( url != "https://raw.githubusercontent.com/mwittrien/BetterDiscordAddons/master/Plugins/PluginRepo/PluginRepo.plugin.js" && body . indexOf ( "const config = {" ) > - 1 && body . indexOf ( "index.js" ) > - 1 && body . indexOf ( "discord_id" ) > - 1 && body . indexOf ( "github_raw" ) > - 1 ) {
let configstring = body . split ( "const config = {" ) [ 1 ] . split ( "};" ) [ 0 ] . replace ( /[\n\r\t]/g , "" ) . replace ( /:\s|\s:/g , ":" ) . replace ( /["'`]:/g , ":" ) . replace ( /([{,])["'`]/g , "$1" ) . split ( "info:{" ) [ 1 ] . split ( ",github:" ) [ 0 ] ;
2018-11-25 19:54:05 +01:00
for ( let tag of tags ) {
2018-11-25 23:57:37 +01:00
let result = tag != "getAuthor" ? new RegExp ( tag . replace ( "get" , "" ) . toLowerCase ( ) + ":([\"|\'|\`]).*\\1" , "gi" ) . exec ( configstring ) : /authors:\[{name:([\"|\'|\`]).*\1/gi . exec ( configstring ) ;
if ( result ) {
var separator = result [ 1 ] ;
result = result [ 0 ] . replace ( new RegExp ( "\\\\" + separator , "g" ) , separator ) . split ( separator ) ;
if ( result . length > 2 ) {
result = tag != "getDescription" ? result [ 1 ] : result . slice ( 1 , - 1 ) . join ( separator ) . replace ( new RegExp ( "\\\\n" , "g" ) , "<br>" ) . replace ( new RegExp ( "\\\\" , "g" ) , "" ) ;
plugin [ tag ] = tag != "getVersion" ? result . charAt ( 0 ) . toUpperCase ( ) + result . slice ( 1 ) : result ;
}
}
}
}
else if ( url . indexOf ( "https://raw.githubusercontent.com/samogot/" ) > - 1 ) {
let configstring = body . replace ( /[\n\r\t]/g , "" ) . split ( 'module.exports = {"info": {' ) [ 1 ] . split ( "};" ) [ 0 ] . replace ( /:\s|\s:/g , ":" ) . replace ( /["'`]:/g , ":" ) . replace ( /([{,])["'`]/g , "$1" ) ;
for ( let tag of tags ) {
let result = tag != "getAuthor" ? new RegExp ( tag . replace ( "get" , "" ) . toLowerCase ( ) + ":([\"|\'|\`]).*\\1" , "gi" ) . exec ( configstring ) : /authors:\[([\"|\'|\`]).*\1/gi . exec ( configstring ) ;
if ( result ) {
var separator = result [ 1 ] ;
result = result [ 0 ] . replace ( new RegExp ( "\\\\" + separator , "g" ) , separator ) . split ( separator ) ;
if ( result . length > 2 ) {
2018-11-26 00:10:30 +01:00
plugin [ tag ] = tag != "getVersion" ? result [ 1 ] . charAt ( 0 ) . toUpperCase ( ) + result [ 1 ] . slice ( 1 ) : result [ 1 ] ;
2018-11-25 23:57:37 +01:00
}
}
2018-11-25 19:54:05 +01:00
}
}
else {
for ( let tag of tags ) {
let result = new RegExp ( tag + "[\\s|\\t|\\n|\\r|=|>|_|:|function|\(|\)|\{|return]*([\"|\'|\`]).*\\1" , "gi" ) . exec ( bodycopy ) ;
2018-11-25 23:57:37 +01:00
if ( ! result ) result = new RegExp ( "get " + tag . replace ( "get" , "" ) . toLowerCase ( ) + "[\\s|\\t|\\n|\\r|=|>|_|:|function|\(|\)|\{|return]*([\"|\'|\`]).*\\1" , "gi" ) . exec ( bodycopy ) ;
2018-11-25 19:54:05 +01:00
if ( result ) {
let separator = result [ 1 ] ;
result = result [ 0 ] . replace ( new RegExp ( "\\\\" + separator , "g" ) , separator ) . split ( separator ) ;
if ( result . length > 2 ) {
result = result . slice ( 1 , - 1 ) . join ( separator ) . replace ( new RegExp ( "\\\\n" , "g" ) , "<br>" ) . replace ( new RegExp ( "\\\\" , "g" ) , "" ) ;
plugin [ tag ] = tag != "getVersion" ? result . charAt ( 0 ) . toUpperCase ( ) + result . slice ( 1 ) : result ;
}
2018-10-11 10:21:26 +02:00
}
}
}
let valid = true ;
for ( let tag of tags ) {
if ( ! plugin [ tag ] || plugin [ tag ] . length > 10000 ) valid = false ;
}
if ( valid ) {
plugin . url = url ;
this . loadedPlugins [ url ] = plugin ;
var installedPlugin = window . bdplugins [ plugin . getName ] ? window . bdplugins [ plugin . getName ] . plugin : null ;
if ( installedPlugin && installedPlugin . getAuthor ( ) . toUpperCase ( ) == plugin . getAuthor . toUpperCase ( ) && installedPlugin . getVersion ( ) != plugin . getVersion ) {
if ( PluginUpdates && PluginUpdates . plugins && ! PluginUpdates . plugins [ url ] ) outdated ++ ;
}
}
else {
2018-11-03 18:03:47 +01:00
webviewqueue . push ( { body , url } ) ;
runInWebview ( ) ;
2018-10-11 10:21:26 +02:00
}
}
i ++ ;
2018-11-03 18:03:47 +01:00
getPluginInfo ( callback ) ;
2018-10-11 10:21:26 +02:00
} ) ;
}
2018-11-03 18:03:47 +01:00
createWebview = ( ) => {
2018-10-11 10:21:26 +02:00
return new Promise ( function ( callback ) {
webview = document . createElement ( "webview" ) ;
webview . src = "https://discordapp.com/" ;
webview . setAttribute ( "webview-PluginRepo" , null ) ;
2018-11-25 22:11:03 +01:00
webview . style . setProperty ( "visibility" , "hidden" , "important" ) ;
2018-10-11 10:21:26 +02:00
webview . addEventListener ( "dom-ready" , ( ) => {
2018-11-03 18:03:47 +01:00
callback ( ) ;
2018-10-11 10:21:26 +02:00
} ) ;
document . body . appendChild ( webview ) ;
} ) ;
}
2018-11-03 18:03:47 +01:00
runInWebview = ( ) => {
if ( webviewrunning ) return ;
let webviewdata = webviewqueue . shift ( ) ;
if ( ! webviewdata ) return ;
2018-11-03 21:25:45 +01:00
webviewrunning = true ;
let { body , url } = webviewdata ;
let name = body . replace ( new RegExp ( "\\s*\:\\s*" , "g" ) , ":" ) . split ( '"name":"' ) ;
if ( name . length > 1 ) {
name = name [ 1 ] . split ( '"' ) [ 0 ] ;
webview . getWebContents ( ) . executeJavaScript ( body ) . then ( ( ) => {
2018-12-12 12:21:24 +01:00
webview . getWebContents ( ) . executeJavaScript ( `
2018-11-03 21:25:45 +01:00
var p = new ` + name + ` ( ) ;
var data = {
"getName" : p . getName ( ) ,
"getAuthor" : p . getAuthor ( ) ,
"getVersion" : p . getVersion ( ) ,
"getDescription" : p . getDescription ( )
} ;
Promise . resolve ( data ) ; `
) . then ( ( plugin ) => {
plugin . url = url ;
this . loadedPlugins [ url ] = plugin ;
var installedPlugin = window . bdplugins [ plugin . getName ] ? window . bdplugins [ plugin . getName ] . plugin : null ;
if ( installedPlugin && installedPlugin . getAuthor ( ) . toUpperCase ( ) == plugin . getAuthor . toUpperCase ( ) && installedPlugin . getVersion ( ) != plugin . getVersion ) outdated ++ ;
webview . getWebContents ( ) . reload ( ) ;
webviewrunning = false ;
runInWebview ( ) ;
2018-11-03 18:03:47 +01:00
} ) ;
2018-11-03 21:25:45 +01:00
} ) ;
}
2018-11-03 18:03:47 +01:00
}
2018-10-11 10:21:26 +02:00
}
checkForNewPlugins ( ) {
let request = require ( "request" ) ;
request ( "https://mwittrien.github.io/BetterDiscordAddons/Plugins/PluginRepo/res/PluginList.txt" , ( error , response , result ) => {
2018-12-14 11:43:54 +01:00
if ( response && ! BDFDB . equals ( result . split ( "\n" ) , this . grabbedPlugins ) ) {
this . loading = { is : false , timeout : null , amount : 0 } ;
this . loadPlugins ( ) ;
}
2018-10-11 10:21:26 +02:00
} ) ;
}
downloadPlugin ( entry ) {
let request = require ( "request" ) ;
request ( entry . url , ( error , response , body ) => {
if ( error ) {
BDFDB . showToast ( ` Unable to download Plugin " ${ plugin . getName } ". ` , { type : "danger" } ) ;
}
else {
let filename = entry . url . split ( "/" ) ;
this . createPluginFile ( filename [ filename . length - 1 ] , body ) ;
}
} ) ;
}
createPluginFile ( filename , content ) {
let fileSystem = require ( "fs" ) ;
let path = require ( "path" ) ;
var file = path . join ( BDFDB . getPluginsFolder ( ) , filename ) ;
fileSystem . writeFile ( file , content , ( error ) => {
if ( error ) {
BDFDB . showToast ( ` Unable to save Plugin " ${ filename } ". ` , { type : "danger" } ) ;
}
else {
BDFDB . showToast ( ` Successfully saved Plugin " ${ filename } ". ` , { type : "success" } ) ;
}
} ) ;
}
startPlugin ( entry ) {
var name = entry . name ;
if ( BDFDB . isPluginEnabled ( name ) == false ) {
bdplugins [ name ] . plugin . start ( ) ;
pluginCookie [ name ] = true ;
pluginModule . savePluginData ( ) ;
console . log ( "PluginRepo: started Plugin " + name ) ;
}
}
deletePluginFile ( entry ) {
let fileSystem = require ( "fs" ) ;
let path = require ( "path" ) ;
let filename = entry . url . split ( "/" ) ;
filename = filename [ filename . length - 1 ] ;
var file = path . join ( BDFDB . getPluginsFolder ( ) , filename ) ;
fileSystem . unlink ( file , ( error ) => {
if ( error ) {
BDFDB . showToast ( ` Unable to delete Plugin " ${ filename } ". ` , { type : "danger" } ) ;
}
else {
BDFDB . showToast ( ` Successfully deleted Plugin " ${ filename } ". ` , { type : "success" } ) ;
}
} ) ;
}
stopPlugin ( entry ) {
var name = entry . name ;
if ( BDFDB . isPluginEnabled ( name ) == true ) {
bdplugins [ name ] . plugin . stop ( ) ;
pluginCookie [ name ] = false ;
delete bdplugins [ name ] ;
pluginModule . savePluginData ( ) ;
console . log ( "PluginRepo: stopped Plugin " + name ) ;
}
}
}