Adobe 0046100128056 Scripting Guide - Page 123

Sample Selection Event Listeners

Page 123 highlights

CHAPTER 8: Events Sample Selection Event Listeners 123 #targetengine "session" //Adds an event listener that performs a preflight check on a document //before printing. If the preflight check fails, the script cancels //the print job. main(); function main(){ var myEventListener = app.eventListeners.add("beforePrint", myBeforePrintHandler); } function myBeforePrintHandler(myEvent){ //The parent of the event is the document. var myDocument = myEvent.parent; if(myPreflight(myDocument) == false){ myEvent.stopPropagation(); myEvent.preventDefault(); alert("Document did not pass preflight check."); } else{alert("Document passed preflight check. Ready to print.");} function myPreflight(myDocument){ var myPreflightCheck = true; var myFontCheck = myCheckFonts(myDocument); var myGraphicsCheck = myCheckGraphics(myDocument); alert("Fonts: " + myFontCheck + "\r" + "Links:" + myGraphicsCheck); if((myFontCheck == false)||(myGraphicsCheck == false)){ myPreflightCheck = false; } return myPreflightCheck; } function myCheckFonts(myDocument){ var myFontCheck = true; for(var myCounter = 0; myCounter < myDocument.fonts.length; myCounter ++){ if(myDocument.fonts.item(myCounter).status != FontStatus.installed){ myFontCheck = false; } } return myFontCheck; } function myCheckGraphics(myDocument){ var myGraphicsCheck = true; for(var myCounter = 0; myCounter < myDocument.allGraphics.length; myCounter++){ var myGraphic = myDocument.allGraphics[myCounter]; if(myGraphic.itemLink.status != LinkStatus.normal){ myGraphicsCheck = false; } } return myGraphicsCheck; } } Sample Selection Event Listeners InDesign can respond to events related to selection. When you select or deselect objects in an InDesign document, InDesign generates the afterSelectionChanged event. When you change an attribute (the formatting or position) of the selected object or objects, InDesign generates the afterSelectionAttributeChanged event. These two events are useful when you want to create a script that responds to user actions.

  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54
  • 55
  • 56
  • 57
  • 58
  • 59
  • 60
  • 61
  • 62
  • 63
  • 64
  • 65
  • 66
  • 67
  • 68
  • 69
  • 70
  • 71
  • 72
  • 73
  • 74
  • 75
  • 76
  • 77
  • 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
  • 105
  • 106
  • 107
  • 108
  • 109
  • 110
  • 111
  • 112
  • 113
  • 114
  • 115
  • 116
  • 117
  • 118
  • 119
  • 120
  • 121
  • 122
  • 123
  • 124
  • 125
  • 126
  • 127
  • 128
  • 129
  • 130
  • 131
  • 132
  • 133
  • 134
  • 135
  • 136
  • 137
  • 138
  • 139
  • 140
  • 141
  • 142
  • 143
  • 144
  • 145
  • 146
  • 147
  • 148
  • 149
  • 150
  • 151
  • 152
  • 153
  • 154
  • 155
  • 156
  • 157
  • 158
  • 159
  • 160
  • 161
  • 162
  • 163
  • 164
  • 165
  • 166
  • 167
  • 168
  • 169
  • 170
  • 171
  • 172
  • 173
  • 174
  • 175
  • 176
  • 177
  • 178
  • 179
  • 180
  • 181
  • 182
  • 183
  • 184
  • 185
  • 186
  • 187
  • 188
  • 189
  • 190
  • 191
  • 192
  • 193
  • 194
  • 195
  • 196
  • 197
  • 198
  • 199
  • 200
  • 201
  • 202
  • 203
  • 204
  • 205
  • 206
  • 207
  • 208
  • 209

C
HAPTER
8: Events
Sample Selection Event Listeners
123
#targetengine "session"
//Adds an event listener that performs a preflight check on a document
//before printing. If the preflight check fails, the script cancels
//the print job.
main();
function main(){
var myEventListener = app.eventListeners.add("beforePrint",
myBeforePrintHandler);
}
function myBeforePrintHandler(myEvent){
//The parent of the event is the document.
var myDocument = myEvent.parent;
if(myPreflight(myDocument) == false){
myEvent.stopPropagation();
myEvent.preventDefault();
alert("Document did not pass preflight check.");
}
else{alert("Document passed preflight check. Ready to print.");}
function myPreflight(myDocument){
var myPreflightCheck = true;
var myFontCheck = myCheckFonts(myDocument);
var myGraphicsCheck = myCheckGraphics(myDocument);
alert("Fonts: " + myFontCheck + "\r" + "Links:" + myGraphicsCheck);
if((myFontCheck == false)||(myGraphicsCheck == false)){
myPreflightCheck = false;
}
return myPreflightCheck;
}
function myCheckFonts(myDocument){
var myFontCheck = true;
for(var myCounter = 0; myCounter < myDocument.fonts.length;
myCounter ++){
if(myDocument.fonts.item(myCounter).status != FontStatus.installed){
myFontCheck = false;
}
}
return myFontCheck;
}
function myCheckGraphics(myDocument){
var myGraphicsCheck = true;
for(var myCounter = 0; myCounter < myDocument.allGraphics.length;
myCounter++){
var myGraphic = myDocument.allGraphics[myCounter];
if(myGraphic.itemLink.status != LinkStatus.normal){
myGraphicsCheck = false;
}
}
return myGraphicsCheck;
}
}
Sample Selection Event Listeners
InDesign can respond to events related to selection. When you select or deselect objects in an InDesign
document, InDesign generates the
afterSelectionChanged
event. When you change an attribute (the
formatting or position) of the selected object or objects, InDesign generates the
afterSelectionAttributeChanged
event. These two events are useful when you want to create a script
that responds to user actions.