|
@@ -3,7 +3,7 @@
|
|
//===== By: ==================================================
|
|
//===== By: ==================================================
|
|
//= Euphy
|
|
//= Euphy
|
|
//===== Current Version: =====================================
|
|
//===== Current Version: =====================================
|
|
-//= 1.4a
|
|
|
|
|
|
+//= 1.4b
|
|
//===== Compatible With: =====================================
|
|
//===== Compatible With: =====================================
|
|
//= rAthena SVN r15340+
|
|
//= rAthena SVN r15340+
|
|
//===== Description: =========================================
|
|
//===== Description: =========================================
|
|
@@ -15,48 +15,60 @@
|
|
prontera,164,203,6 script Quest Shop 998,{
|
|
prontera,164,203,6 script Quest Shop 998,{
|
|
function Add; function Chk; function Slot; function A_An;
|
|
function Add; function Chk; function Slot; function A_An;
|
|
|
|
|
|
- if(.Shops$ != "") set .@i,1;
|
|
|
|
- else {
|
|
|
|
- set .@menu$,"";
|
|
|
|
- for(set .@i,1; .@i<=getarraysize(.Shops$); set .@i,.@i+1)
|
|
|
|
- set .@menu$, .@menu$+.Shops$[.@i]+":";
|
|
|
|
- set .@i, select(.@menu$); }
|
|
|
|
|
|
+ if (.Shops$ == "") set .@i, select(.menu$);
|
|
|
|
+ else set .@i,1;
|
|
dispbottom "Select one item at a time.";
|
|
dispbottom "Select one item at a time.";
|
|
callshop "qshop"+.@i,1;
|
|
callshop "qshop"+.@i,1;
|
|
npcshopattach "qshop"+.@i;
|
|
npcshopattach "qshop"+.@i;
|
|
end;
|
|
end;
|
|
|
|
|
|
function Add {
|
|
function Add {
|
|
- if (getitemname(getarg(1))=="null") {
|
|
|
|
- debugmes "Quest reward #"+getarg(1)+" invalid (skipped)."; return; }
|
|
|
|
|
|
+ if (getitemname(getarg(1)) == "null") {
|
|
|
|
+ debugmes "Quest reward #"+getarg(1)+" invalid (skipped).";
|
|
|
|
+ return;
|
|
|
|
+ }
|
|
for(set .@n,5; .@n<127; set .@n,.@n+2) {
|
|
for(set .@n,5; .@n<127; set .@n,.@n+2) {
|
|
if (!getarg(.@n,0)) break;
|
|
if (!getarg(.@n,0)) break;
|
|
- if (getitemname(getarg(.@n))=="null") {
|
|
|
|
- debugmes "Quest requirement #"+getarg(.@n)+" invalid (skipped)."; return; } }
|
|
|
|
|
|
+ if (getitemname(getarg(.@n)) == "null") {
|
|
|
|
+ debugmes "Quest requirement #"+getarg(.@n)+" invalid (skipped).";
|
|
|
|
+ return;
|
|
|
|
+ }
|
|
|
|
+ }
|
|
for(set .@i,2; .@i<.@n; set .@i,.@i+1)
|
|
for(set .@i,2; .@i<.@n; set .@i,.@i+1)
|
|
set getd(".q_"+getarg(1)+"["+(.@i-2)+"]"), getarg(.@i);
|
|
set getd(".q_"+getarg(1)+"["+(.@i-2)+"]"), getarg(.@i);
|
|
npcshopadditem "qshop"+getarg(0),getarg(1),((.ShowZeny)?getarg(3):0);
|
|
npcshopadditem "qshop"+getarg(0),getarg(1),((.ShowZeny)?getarg(3):0);
|
|
- return; }
|
|
|
|
|
|
+ return;
|
|
|
|
+}
|
|
function Chk {
|
|
function Chk {
|
|
- if (getarg(0)<getarg(1)) { set @qe0,1; return "^FF0000"; }
|
|
|
|
- else return "^00FF00"; }
|
|
|
|
|
|
+ if (getarg(0) < getarg(1)) {
|
|
|
|
+ set @qe0,1;
|
|
|
|
+ return "^FF0000";
|
|
|
|
+ }
|
|
|
|
+ else return "^00FF00";
|
|
|
|
+}
|
|
function Slot {
|
|
function Slot {
|
|
set .@s$,getitemname(getarg(0));
|
|
set .@s$,getitemname(getarg(0));
|
|
- switch(.ShowSlot){
|
|
|
|
|
|
+ switch(.ShowSlot) {
|
|
case 1: if (!getitemslots(getarg(0))) return .@s$;
|
|
case 1: if (!getitemslots(getarg(0))) return .@s$;
|
|
- case 2: if (getiteminfo(getarg(0),11)>0) return .@s$+" ["+getitemslots(getarg(0))+"]";
|
|
|
|
- default: return .@s$; } }
|
|
|
|
|
|
+ case 2: if (getiteminfo(getarg(0),2) == 4 || getiteminfo(getarg(0),2) == 5) return .@s$+" ["+getitemslots(getarg(0))+"]";
|
|
|
|
+ default: return .@s$;
|
|
|
|
+ }
|
|
|
|
+}
|
|
function A_An {
|
|
function A_An {
|
|
setarray .@A$[0],"a","e","i","o","u";
|
|
setarray .@A$[0],"a","e","i","o","u";
|
|
set .@B$, "_"+getarg(0);
|
|
set .@B$, "_"+getarg(0);
|
|
for(set .@i,0; .@i<5; set .@i,.@i+1)
|
|
for(set .@i,0; .@i<5; set .@i,.@i+1)
|
|
if (compare(.@B$,"_"+.@A$[.@i])) return "an "+getarg(0);
|
|
if (compare(.@B$,"_"+.@A$[.@i])) return "an "+getarg(0);
|
|
- return "a "+getarg(0); }
|
|
|
|
|
|
+ return "a "+getarg(0);
|
|
|
|
+}
|
|
|
|
|
|
OnBuyItem:
|
|
OnBuyItem:
|
|
set .@q[0],@bought_nameid;
|
|
set .@q[0],@bought_nameid;
|
|
copyarray .@q[1],getd(".q_"+@bought_nameid+"[0]"),getarraysize(getd(".q_"+@bought_nameid+"[0]"));
|
|
copyarray .@q[1],getd(".q_"+@bought_nameid+"[0]"),getarraysize(getd(".q_"+@bought_nameid+"[0]"));
|
|
- if (!.@q[1]) { message strcharinfo(0),"An error has occurred."; end; }
|
|
|
|
|
|
+ if (!.@q[1]) {
|
|
|
|
+ message strcharinfo(0),"An error has occurred.";
|
|
|
|
+ end;
|
|
|
|
+ }
|
|
mes "[Quest Shop]";
|
|
mes "[Quest Shop]";
|
|
mes "Reward: ^0055FF"+((.@q[1]>1)?.@q[1]+"x ":"")+Slot(.@q[0])+"^000000";
|
|
mes "Reward: ^0055FF"+((.@q[1]>1)?.@q[1]+"x ":"")+Slot(.@q[0])+"^000000";
|
|
mes "Requirements:";
|
|
mes "Requirements:";
|
|
@@ -65,39 +77,51 @@ OnBuyItem:
|
|
if (.@q[4]) for(set .@i,4; .@i<getarraysize(.@q); set .@i,.@i+2)
|
|
if (.@q[4]) for(set .@i,4; .@i<getarraysize(.@q); set .@i,.@i+2)
|
|
mes " > "+Chk(countitem(.@q[.@i]),.@q[.@i+1])+((.DisplayID)?"{"+.@q[.@i]+"} ":"")+Slot(.@q[.@i])+" ("+countitem(.@q[.@i])+"/"+.@q[.@i+1]+")^000000";
|
|
mes " > "+Chk(countitem(.@q[.@i]),.@q[.@i+1])+((.DisplayID)?"{"+.@q[.@i]+"} ":"")+Slot(.@q[.@i])+" ("+countitem(.@q[.@i])+"/"+.@q[.@i+1]+")^000000";
|
|
next;
|
|
next;
|
|
- set @qe1, getiteminfo(.@q[0],5); set @qe2, getiteminfo(.@q[0],11);
|
|
|
|
|
|
+ set @qe1, getiteminfo(.@q[0],5);
|
|
|
|
+ set @qe2, getiteminfo(.@q[0],11);
|
|
addtimer 1000, strnpcinfo(1)+"::OnEnd";
|
|
addtimer 1000, strnpcinfo(1)+"::OnEnd";
|
|
- while(1){
|
|
|
|
- switch(select(" ~ Purchase ^0055FF"+getitemname(.@q[0])+"^000000:"+((((@qe1&1) || (@qe1&256) || (@qe1&512)) && @qe2>0 && !@qe6)?" ~ Preview...":"")+": ~ ^777777Cancel^000000")) {
|
|
|
|
- case 1:
|
|
|
|
- if (@qe0) {
|
|
|
|
- mes "[Quest Shop]";
|
|
|
|
- mes "You're missing one or more quest requirements.";
|
|
|
|
- close; }
|
|
|
|
- if (!checkweight(.@q[0],.@q[1])) {
|
|
|
|
- mes "[Quest Shop]";
|
|
|
|
- mes "^FF0000You need "+(((.@q[1]*getiteminfo(.@q[0],6))+Weight-MaxWeight)/10)+" additional weight capacity to complete this trade.^000000";
|
|
|
|
- close; }
|
|
|
|
- if (.@q[2]) set Zeny, Zeny-.@q[2];
|
|
|
|
- if (.@q[3]) setd .Points$[0], getd(.Points$[0])-.@q[3];
|
|
|
|
- if (.@q[4]) for(set .@i,4; .@i<getarraysize(.@q); set .@i,.@i+2)
|
|
|
|
- delitem .@q[.@i],.@q[.@i+1];
|
|
|
|
- getitem .@q[0],.@q[1];
|
|
|
|
- if (.Announce) announce strcharinfo(0)+" has created "+A_An(getitemname(.@q[0]))+"!",0;
|
|
|
|
- specialeffect2 699;
|
|
|
|
|
|
+ while(1) {
|
|
|
|
+ switch(select(" ~ Purchase ^0055FF"+getitemname(.@q[0])+"^000000:"+((((@qe1&1) || (@qe1&256) || (@qe1&512)) && @qe2 > 0 && !@qe6)?" ~ Preview...":"")+": ~ ^777777Cancel^000000")) {
|
|
|
|
+ case 1:
|
|
|
|
+ if (@qe0) {
|
|
|
|
+ mes "[Quest Shop]";
|
|
|
|
+ mes "You're missing one or more quest requirements.";
|
|
|
|
+ close;
|
|
|
|
+ }
|
|
|
|
+ if (!checkweight(.@q[0],.@q[1])) {
|
|
|
|
+ mes "[Quest Shop]";
|
|
|
|
+ mes "^FF0000You need "+(((.@q[1]*getiteminfo(.@q[0],6))+Weight-MaxWeight)/10)+" additional weight capacity to complete this trade.^000000";
|
|
close;
|
|
close;
|
|
- case 2:
|
|
|
|
- set @qe3, getlook(3); set @qe4, getlook(4); set @qe5, getlook(5);
|
|
|
|
- if (@qe1&1) atcommand "@changelook 3 "+@qe2;
|
|
|
|
- if (@qe1&256) atcommand "@changelook 1 "+@qe2;
|
|
|
|
- if (@qe1&512) atcommand "@changelook 2 "+@qe2;
|
|
|
|
- set @qe6,1;
|
|
|
|
- break;
|
|
|
|
- case 3:
|
|
|
|
- close; } }
|
|
|
|
|
|
+ }
|
|
|
|
+ if (.@q[2]) set Zeny, Zeny-.@q[2];
|
|
|
|
+ if (.@q[3]) setd .Points$[0], getd(.Points$[0])-.@q[3];
|
|
|
|
+ if (.@q[4]) for(set .@i,4; .@i<getarraysize(.@q); set .@i,.@i+2)
|
|
|
|
+ delitem .@q[.@i],.@q[.@i+1];
|
|
|
|
+ getitem .@q[0],.@q[1];
|
|
|
|
+ if (.Announce) announce strcharinfo(0)+" has created "+A_An(getitemname(.@q[0]))+"!",0;
|
|
|
|
+ specialeffect2 699;
|
|
|
|
+ close;
|
|
|
|
+ case 2:
|
|
|
|
+ set @qe3, getlook(3);
|
|
|
|
+ set @qe4, getlook(4);
|
|
|
|
+ set @qe5, getlook(5);
|
|
|
|
+ set @qe6,1;
|
|
|
|
+ if (@qe1&1) atcommand "@changelook 3 "+@qe2;
|
|
|
|
+ if (@qe1&256) atcommand "@changelook 1 "+@qe2;
|
|
|
|
+ if (@qe1&512) atcommand "@changelook 2 "+@qe2;
|
|
|
|
+ break;
|
|
|
|
+ case 3:
|
|
|
|
+ close;
|
|
|
|
+ }
|
|
|
|
+ }
|
|
OnEnd:
|
|
OnEnd:
|
|
- if (@qe6) { atcommand "@changelook 3 "+@qe3; atcommand "@changelook 1 "+@qe4; atcommand "@changelook 2 "+@qe5; }
|
|
|
|
- for(set .@i,0; .@i<7; set .@i,.@i+1) setd "@qe"+.@i,0;
|
|
|
|
|
|
+ if (@qe6) {
|
|
|
|
+ atcommand "@changelook 3 "+@qe3;
|
|
|
|
+ atcommand "@changelook 1 "+@qe4;
|
|
|
|
+ atcommand "@changelook 2 "+@qe5;
|
|
|
|
+ }
|
|
|
|
+ for(set .@i,0; .@i<7; set .@i,.@i+1)
|
|
|
|
+ setd "@qe"+.@i,0;
|
|
end;
|
|
end;
|
|
OnInit:
|
|
OnInit:
|
|
freeloop(1);
|
|
freeloop(1);
|
|
@@ -137,8 +161,11 @@ OnInit:
|
|
|
|
|
|
// --------------------------------------------------
|
|
// --------------------------------------------------
|
|
freeloop(0);
|
|
freeloop(0);
|
|
- for(set .@i,1; .@i<=getarraysize(.Shops$); set .@i,.@i+1)
|
|
|
|
|
|
+ set .menu$,"";
|
|
|
|
+ for(set .@i,1; .@i<=getarraysize(.Shops$); set .@i,.@i+1) {
|
|
|
|
+ set .menu$, .menu$+.Shops$[.@i]+":";
|
|
npcshopdelitem "qshop"+.@i,909;
|
|
npcshopdelitem "qshop"+.@i,909;
|
|
|
|
+ }
|
|
end;
|
|
end;
|
|
}
|
|
}
|
|
|
|
|