Subversion Repositories munaweb

Rev

Rev 17 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
2 - 1
<!DOCTYPE html>
2
<html lang="en">
3
 
4
<head>
5
    <title>eBay Listing Upload</title>
6
    <meta charset="UTF-8">
7
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
8
    <link rel="shortcut icon" href="favicon.ico" type="image/x-icon">
9
    <link rel="icon" href="favicon.ico" type="image/x-icon">
10
 
11
    <link rel="stylesheet" href="https://www.w3schools.com/w3css/4/w3.css">
12
    <link href="https://fonts.googleapis.com/css?family=Lato" rel="stylesheet">
13
    <link rel="stylesheet" href="css/style.css">
14
    <script src="js/XMLWriter.js"></script>
15
    <script src="js/lodash.min.js"></script>
16
    <script src="js/muna-tools.js"></script>
17
</head>
18
 
19
<body onload="return initConfig();">
20
    <div class="w3-main">
21
        <div class="w3-container w3-padding w3-margin w3-card-4">
22
            <div class="w3-container w3-gray" style="height:100px">
23
                <img class="w3-image" src="images/MUNA%20-%20Logo%20100x100.png" alt="MUNA Trading Logo" style="height:100px">
24
                <p id="connected" class="w3-xxlarge w3-right">eBay Listing Upload
25
                    <input id="login" type="button" class="w3-btn w3-large w3-green w3-margin w3-round-large w3-ripple w3-right w3-hide" onclick="eBayLogin();" value="Login" />
26
                </p>
27
            </div>
28
 
29
            <div class="w3-row">
30
                <div>
31
                    <form id="searchForm" class="w3-container w3-light-grey w3-padding w3-small">
32
                        <div class="w3-container w3-card-2 w3-cell w3-padding">
6 - 33
                            <input id="startButton" type="button" class="w3-btn w3-large w3-red w3-margin w3-round-large w3-ripple" onclick="uploadListings();" value="Start" />
34
                            <p id="numberOfListings" class="w3-right"></p>
2 - 35
                        </div>
36
                    </form>
37
                </div>
38
                <div id="progressBarDiv" class="w3-container w3-padding w3-margin w3-card-4 w3-hide">
39
                    <h2 id="progressBarHeader"></h2>
40
                    <div class="w3-light-grey">
41
                        <div id="progressBar" class="w3-container w3-green w3-center" style="width:0%">0%</div>
42
                    </div>
43
                </div>
44
                <div id="logging" class="w3-container w3-padding"></div>
45
                <div id="results" class="w3-container w3-padding w3-card-4 w3-hide"></div>
46
            </div>
47
        </div>
48
 
49
        <footer class="w3-container w3-center w3-border-top w3-margin">
17 - 50
            <div w3-include-html="php/footer.php"></div>
2 - 51
        </footer>
52
 
53
    </div>
54
 
55
    <script>
56
 
57
// Globals
58
var configGetRecommendations = true;
59
var xml = '';
60
var listItems = [];
61
 
62
// Initialize Configuration Variables
63
function initConfig() {
6 - 64
    var i;
65
    var j;
2 - 66
 
6 - 67
    eBayAuthToken = readCookie();
68
    if (eBayAuthToken.length > 0) {
69
        connected();
70
    }
2 - 71
 
6 - 72
    if (eBayAuthTokenFlag === false) {
73
        var x = document.getElementById("login");
74
        if (x.className.indexOf("w3-show") == -1) {
75
            x.className += " w3-show";
76
        }
77
    }
2 - 78
 
6 - 79
    var xhttp = new XMLHttpRequest();
80
    xhttp.onreadystatechange = function() {
81
        if (this.readyState == 4 && this.status == 200) {
82
            //window.alert(this.responseText);
2 - 83
 
6 - 84
            var parser = new DOMParser();
85
            var htmlDoc = parser.parseFromString(this.responseText, "text/html");
86
            var x = htmlDoc.getElementsByTagName("a");
2 - 87
 
6 - 88
            listItems = [];
2 - 89
 
6 - 90
            for (i = 0, j = 0; i < x.length; i++) {
91
                if (htmlDoc.getElementsByTagName("a")[i].innerHTML.endsWith(".xml")) {
92
                    var n = htmlDoc.getElementsByTagName("a")[i].innerHTML.lastIndexOf(".xml");
93
                    listItems[j] = htmlDoc.getElementsByTagName("a")[i].innerHTML.substr(0, n);
94
                    j++;
95
                }
96
            }
2 - 97
 
6 - 98
            document.getElementById('numberOfListings').innerHTML = j + ' Listing(s) Ready for eBay Upload';
99
        }
100
    };
2 - 101
 
6 - 102
    xhttp.open("GET", configListingUrl + '?t=' + Math.random(), true);
103
    xhttp.send();
2 - 104
}
105
 
106
function requireNewLogin() {
6 - 107
    // dummy
2 - 108
}
109
 
110
function uploadListings() {
6 - 111
    var i = 0;
2 - 112
 
6 - 113
    document.getElementById("logging").innerHTML = '';
114
    document.getElementById("results").innerHTML = '';
2 - 115
 
6 - 116
    initProgressBar('Uploading Listings');
2 - 117
 
6 - 118
    function for1() {
119
        updateProgressBar(listItems.length, i);
120
        uploadListing(listItems[i]);
121
        for2();
122
    }
2 - 123
 
6 - 124
    function for2() {
125
        if (i == listItems.length) {
126
            endProgressBar();
127
            return false;
128
        }
2 - 129
 
6 - 130
        setTimeout(function() {
131
            i++;
132
            document.getElementById("logging").innerHTML = 'Uploading No. ' + i + '/' + listItems.length;
133
            for1();
134
        }, 500);
135
    }
2 - 136
 
6 - 137
    for1();
2 - 138
}
139
 
140
function uploadListing(name) {
6 - 141
    var xhttp;
2 - 142
 
6 - 143
    xhttp = new XMLHttpRequest();
2 - 144
 
6 - 145
    xhttp.onreadystatechange = function() {
146
        if (this.readyState == 4 && this.status == 200) {
147
            //			verifyListing(name, xhttp.responseText);
148
            submitListing(name, xhttp.responseText);
149
        }
150
    };
2 - 151
 
6 - 152
    xhttp.open("GET", configListingUrl + name + '.xml', true);
153
    xhttp.send();
2 - 154
}
155
 
156
function verifyListing(name, itemXML) {
6 - 157
    var i;
158
    var authErrorFlag = false;
2 - 159
 
6 - 160
    if (eBayAuthTokenFlag === false) {
161
        return;
162
    }
2 - 163
 
6 - 164
    var xw = new XMLWriter('UTF-8', '1.0');
165
    var xhr = new XMLHttpRequest();
2 - 166
 
6 - 167
    createAddXML(xw, xhr, 'VerifyAddItemRequest', 'VerifyAddItem', itemXML);
2 - 168
 
6 - 169
    xml = xw.flush();
170
    xw.close();
2 - 171
 
6 - 172
    xhr.onload = function() {
12 - 173
        var jsonObj = XMLparse(xhr.responseXML, false);
174
        var obj = jsonObj.VerifyAddItemResponse;
6 - 175
        var returnCode = obj.Ack;
19 - 176
        var str;
2 - 177
 
6 - 178
        var x = document.getElementById("results");
179
        if (x.className.indexOf("w3-show") == -1) {
180
            x.className += " w3-show";
181
        }
2 - 182
 
6 - 183
        if (returnCode == 'Success' || (returnCode == 'Warning' && obj.Errors.ErrorCode == '21917108')) {
19 - 184
            str = '<p><strong>' + returnCode + ' (' + name + ')</strong></p>';
2 - 185
 
6 - 186
            if (returnCode == 'Warning') {
19 - 187
                str += "<p>" + obj.Errors.SeverityCode + " (" + obj.Errors.ErrorCode + "): " + escapeHtml(obj.Errors.LongMessage) + "</p>";
6 - 188
            }
12 - 189
            var fees = getJsonArray(obj.Fees.Fee);
19 - 190
            str += "<p>";
6 - 191
            for (i = 0; i < fees.length; i++) {
192
                if (fees[i].Fee.text !== "0.0") {
19 - 193
                    str += fees[i].Name + ": $" + Number(fees[i].Fee.text).toFixed(2) + "<br/>";
6 - 194
                }
195
            }
19 - 196
            str += "</p>";
2 - 197
 
6 - 198
            if (obj.DiscountReason) {
19 - 199
                str += "<p>Discount Reason: " + obj.DiscountReason + "</p>";
6 - 200
            }
2 - 201
 
6 - 202
            var recommendations = getJsonArray(obj.ListingRecommendations);
203
            for (i = 0; i < recommendations.length; i++) {
19 - 204
                str += decode(recommendations[i]);
6 - 205
            }
19 - 206
 
207
            x.innerHTML += str;
6 - 208
        } else {
19 - 209
            str = '<p class="w3-red"><strong>' + returnCode + ' (' + name + ')</strong></p>';
2 - 210
 
6 - 211
            var errors = getJsonArray(obj.Errors);
19 - 212
            str += "<p>";
6 - 213
            for (i = 0; i < errors.length; i++) {
19 - 214
                str += errors[i].SeverityCode + " (" + errors[i].ErrorCode + "): " + escapeHtml(errors[i].LongMessage) + "<br/>";
6 - 215
                if (errors[i].LongMessage.includes('Auth')) {
216
                    authErrorFlag = true;
217
                }
218
            }
19 - 219
            str += "</p>";
2 - 220
 
6 - 221
            if (obj.DuplicateInvocationDetails) {
19 - 222
                str += '<p>Duplicate Invocation Id ' + obj.DuplicateInvocationDetails.DuplicateInvocationID + ' Tracking Id' + obj.DuplicateInvocationDetails.InvocationTrackingID + ' Status ' + obj.DuplicateInvocationDetails.Status + '</p>';
6 - 223
            }
2 - 224
 
19 - 225
            x.innerHTML += str;
226
 
6 - 227
            if (authErrorFlag === true) {
228
                eBayAuthTokenFlag = false;
229
                x = document.getElementById("login");
230
                if (x.className.indexOf("w3-show") == -1) {
231
                    x.className += " w3-show";
232
                }
233
            }
234
        }
2 - 235
 
6 - 236
        if (obj.Message) {
237
            x.innerHTML += obj.Message;
238
        }
239
    };
2 - 240
 
6 - 241
    xhr.send(xml);
2 - 242
}
243
 
244
function decode(recommendation) {
6 - 245
    var str = "<p>";
246
    var i;
2 - 247
 
6 - 248
    str += recommendation.Code + " (" + recommendation.Type + "/" + recommendation.Group + ") for '" + recommendation.FieldName;
249
    if (recommendation.Value) {
250
        str += "': " + recommendation.Value;
251
    }
2 - 252
 
6 - 253
    if (recommendation.Message) {
254
        str += "<br/>" + recommendation.Message;
255
    }
2 - 256
 
6 - 257
    var metadata = recommendation.Metadata;
258
    if (metadata) {
259
        if (metadata.length > 0) {
260
            for (i = 0; i < metadata.length; i++) {
261
                if (metadata[i].Name != "correlationId" &&
262
                    metadata[i].Name != "currency" &&
263
                    metadata[i].Name != "similarItems") {
264
                    str += "<br/>" + metadata[i].Name + " = " + metadata[i].Value;
265
                }
266
            }
267
        } else {
268
            if (metadata.Name != "correlationId" &&
269
                metadata.Name != "currency" &&
270
                metadata.Name != "similarItems") {
271
                str += "<br/>" + metadata.Name + " = " + metadata.Value;
272
            }
273
        }
274
    }
2 - 275
 
6 - 276
    str += "</p>";
2 - 277
 
6 - 278
    return str;
2 - 279
}
280
 
281
function submitListing(name, itemXML) {
6 - 282
    var i;
283
    var authErrorFlag = false;
2 - 284
 
6 - 285
    if (document.getElementById("startButton").className.indexOf("w3-green") == -1) {
286
        return;
287
    }
2 - 288
 
6 - 289
    var xw = new XMLWriter('UTF-8', '1.0');
290
    var xhr = new XMLHttpRequest();
2 - 291
 
6 - 292
    createAddXML(xw, xhr, 'AddItemRequest', 'AddItem', itemXML);
2 - 293
 
6 - 294
    xml = xw.flush();
295
    xw.close();
2 - 296
 
6 - 297
    xhr.onload = function() {
12 - 298
        var jsonObj = XMLparse(xhr.responseXML, false);
299
        var obj = jsonObj.AddItemResponse;
6 - 300
        var returnCode = obj.Ack;
19 - 301
        var str;
2 - 302
 
6 - 303
        var x = document.getElementById("results");
304
        if (x.className.indexOf("w3-show") == -1) {
305
            x.className += " w3-show";
306
        }
2 - 307
 
6 - 308
        if (returnCode == 'Success' || (returnCode == 'Warning' && obj.Errors.ErrorCode == '21917108')) {
19 - 309
            str = '<p><strong>' + returnCode + '</strong>, Item Id <a href="https://www.ebay.com/itm/' + obj.ItemID + '" target="_blank">' + obj.ItemID + '</a> (' + name + ')</p>';
6 - 310
            if (returnCode == 'Warning') {
19 - 311
                str += "<p>" + obj.Errors.SeverityCode + " (" + obj.Errors.ErrorCode + "): " + escapeHtml(obj.Errors.LongMessage) + "</p>";
6 - 312
            }
2 - 313
 
12 - 314
            var fees = getJsonArray(obj.Fees.Fee);
19 - 315
            str += "<p>";
6 - 316
            for (i = 0; i < fees.length; i++) {
317
                if (fees[i].Fee.text !== "0.0") {
19 - 318
                    str += fees[i].Name + ": $" + Number(fees[i].Fee.text).toFixed(2) + "<br/>";
6 - 319
                }
320
            }
19 - 321
            str += "</p>";
2 - 322
 
6 - 323
            if (obj.DiscountReason) {
19 - 324
                str += "<p>Discount Reason: " + obj.DiscountReason + "</p>";
6 - 325
            }
19 - 326
 
327
            x.innerHTML += str;
6 - 328
        } else {
19 - 329
            str = '<p class="w3-red"><strong>' + returnCode + ' (' + name + ')</strong></p>';
2 - 330
 
6 - 331
            var errors = getJsonArray(obj.Errors);
19 - 332
            str += "<p>";
6 - 333
            for (i = 0; i < errors.length; i++) {
19 - 334
                str += errors[i].SeverityCode + " (" + errors[i].ErrorCode + "): " + escapeHtml(errors[i].LongMessage) + "<br/>";
6 - 335
                if (errors[i].LongMessage.includes('Auth')) {
336
                    authErrorFlag = true;
337
                }
338
            }
19 - 339
            str += "</p>";
2 - 340
 
6 - 341
            if (obj.DuplicateInvocationDetails) {
19 - 342
                str += '<p>Duplicate Invocation Id ' + obj.DuplicateInvocationDetails.DuplicateInvocationID + ' Tracking Id' + obj.DuplicateInvocationDetails.InvocationTrackingID + ' Status ' + obj.DuplicateInvocationDetails.Status + '</p>';
6 - 343
            }
2 - 344
 
19 - 345
            x.innerHTML += str;
346
 
6 - 347
            if (authErrorFlag === true) {
348
                eBayAuthTokenFlag = false;
349
                x = document.getElementById("login");
350
                if (x.className.indexOf("w3-show") == -1) {
351
                    x.className += " w3-show";
352
                }
353
            }
354
        }
355
    };
2 - 356
 
6 - 357
    xhr.send(xml);
2 - 358
}
359
 
360
function createAddXML(xw, xhr, xmlrequest, callname, itemXML) {
6 - 361
    xw.writeStartDocument();
362
    xw.writeStartElement(xmlrequest);
363
    xw.writeAttributeString('xmlns', 'urn:ebay:apis:eBLBaseComponents');
2 - 364
 
6 - 365
    xw.writeStartElement('RequesterCredentials');
366
    xw.writeElementString('eBayAuthToken', eBayAuthToken);
367
    xw.writeEndElement(); /* RequesterCredentials */
2 - 368
 
6 - 369
    xw.writeXML(itemXML);
2 - 370
 
6 - 371
    xw.writeElementString('ErrorLanguage', 'en_US');
372
    xw.writeElementString('Version', configeBayTradingVersion);
373
    xw.writeElementString('WarningLevel', configWarningLevel);
2 - 374
 
6 - 375
    xw.writeEndElement(); /* xmlrequest */
376
    xw.writeEndDocument();
2 - 377
 
6 - 378
    xhr.open('POST', configProxyUrl, true);
379
    xhr.setRequestHeader('Content-Type', 'text/xml');
380
    xhr.setRequestHeader('X-EBAY-API-APP-NAME', configAppid);
381
    xhr.setRequestHeader('X-EBAY-API-COMPATIBILITY-LEVEL', configeBayTradingVersion);
382
    xhr.setRequestHeader('X-EBAY-API-CALL-NAME', callname);
383
    xhr.setRequestHeader('X-EBAY-API-SITEID', '0');
384
    xhr.setRequestHeader('X-EBAY-API-DEV-NAME', '');
385
    xhr.setRequestHeader('X-EBAY-API-CERT-NAME', '');
386
    xhr.setRequestHeader('X-Proxy-URL', configServiceEndpoint);
2 - 387
}
388
 
389
function clearStatusWindows() {
6 - 390
    var x = document.getElementById("results");
391
    x.innerHTML = "";
392
    x.className = x.className.replace(" w3-show", "");
2 - 393
}
394
 
395
function connected() {
6 - 396
    var x;
2 - 397
 
6 - 398
    eBayAuthTokenFlag = true;
399
    document.getElementById("connected").innerHTML += " (Connected)";
2 - 400
 
6 - 401
    x = document.getElementById("startButton");
402
    x.className = x.className.replace(" w3-red", " w3-green");
2 - 403
 
6 - 404
    x = document.getElementById("login");
405
    x.className = x.className.replace(" w3-show", "");
2 - 406
}
407
 
408
    </script>
17 - 409
    <script>includeHTML();</script>
2 - 410
 
411
</body>
412
</html>