-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathname-color-layers.js
144 lines (126 loc) · 3.95 KB
/
name-color-layers.js
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
#target Illustrator
// script.name = name-color-layers.js;
// script.description = Loop into each Artboard and set a name on each path that has stroke, transparency and color;
// script.requirement = one document with at least one artboard;
// script.parent = pixeden;
// script.elegant = false;
if (app.documents.length > 0) {
var doc = app.activeDocument
colorIconsLayers()
} else {
alert ("There is no open document.")
}
function colorIconsLayers () {
var artbsString = prompt ("Enter Indexes of Artboards to process (comma separated), empty for all Artboards.", "", "Copy Artboards")
var pathCount = doc.pathItems.length
var compPathCount = doc.compoundPathItems.length
var groupCount = doc.groupItems.length
if (artbsString != null) {
var onlySelected = artbsString !== ''
var lengthLoop = doc.artboards.length
var selArtbs = []
if (onlySelected) {
selArtbs = artbsString.split(',')
lengthLoop = selArtbs.length
}
// Loop into each Artboard
for (i = 0; i < lengthLoop; i++) {
var usedLayers = new Array()
var index = i
if (onlySelected) {
index = selArtbs[i]-1
}
selectArtboardByIndex(index)
// Simple Paths Loop
if (pathCount > 0) {
for (var y = 0; y < pathCount; y++) {
usedLayers = processPath(doc.pathItems[y], usedLayers)
}
}
// Compound Paths Loop
if (compPathCount > 0) {
for (var z = 0; z < compPathCount; z++) {
usedLayers = processPath(doc.compoundPathItems[z], usedLayers)
}
}
// Groups Loop
if (groupCount > 0) {
for (var g = 0; g < groupCount; g++) {
usedLayers = processPath(doc.groupItems[g], usedLayers)
}
}
}
} else {
alert('bye…')
}
}
function processPath (path, usedLayers) {
var strokeName = 'stroke'
var opacityName = 'opacity'
var testPath = isCompoundPath(path) && path.pathItems.length > 0 ? path.pathItems[0] : path
if (path.selected) {
if (isStroked(testPath)) {
path.name = strokeName
}
if (isOpacity(testPath)) {
path.name = opacityName
}
if (isFilled(testPath) && path.parent.opacity === 100) {
var pathColor = getColor(testPath)
if (usedLayers.length > 0) {
for (var i = 0; i < usedLayers.length; i++) {
if (isEqualColor(usedLayers[i],pathColor)) {
path.name = 'layer' + Number(i + 1)
return usedLayers
}
}
path.name = 'layer' + Number(usedLayers.length + 1)
return usedLayers.concat(pathColor)
} else {
path.name = 'layer1'
return usedLayers.concat(pathColor)
}
}
}
return usedLayers
}
function isEqualColor (obj1, obj2) {
return isCMYK() ?
obj1.cyan === obj2.cyan &&
obj1.magenta === obj2.magenta &&
obj1.yellow === obj2.yellow &&
obj1.black === obj2.black
:
obj1.red === obj2.red &&
obj1.green === obj2.green &&
obj1.blue === obj2.blue
}
function isStroked (path) { return path.stroked && !path.filled }
function isFilled (path) { return path.filled && !path.stroked && path.opacity === 100 }
function isOpacity (path) { return path.opacity < 100 }
function isCompoundPath (path) { return path.typename === "CompoundPathItem" }
function selectArtboardByIndex (index) {
doc.selection = null
doc.artboards.setActiveArtboardIndex(index)
doc.selectObjectsOnActiveArtboard()
}
function setDefaultLayer () {
return isCMYK() ?
{ cyan: '', magenta: '', yellow: '', black: '' } :
{ red: '', green: '', blue: '' }
}
function isCMYK () {
return doc.documentColorSpace == 'DocumentColorSpace.CMYK'
}
function getColor (path) {
return isCMYK() ? {
cyan: path.fillColor.cyan,
magenta: path.fillColor.magenta,
yellow: path.fillColor.yellow,
black: path.fillColor.black,
} : {
red: path.fillColor.red,
green: path.fillColor.green,
blue: path.fillColor.blue,
}
}