source: imaps-frontend/node_modules/postcss/lib/container.d.ts@ 0c6b92a

main
Last change on this file since 0c6b92a was 0c6b92a, checked in by stefan toskovski <stefantoska84@…>, 5 weeks ago

Pred finalna verzija

  • Property mode set to 100644
File size: 13.7 KB
Line 
1import AtRule from './at-rule.js'
2import Comment from './comment.js'
3import Declaration from './declaration.js'
4import Node, { ChildNode, ChildProps, NodeProps } from './node.js'
5import Rule from './rule.js'
6
7declare namespace Container {
8 export class ContainerWithChildren<
9 Child extends Node = ChildNode
10 > extends Container_<Child> {
11 nodes: Child[]
12 }
13
14 export interface ValueOptions {
15 /**
16 * String that’s used to narrow down values and speed up the regexp search.
17 */
18 fast?: string
19
20 /**
21 * An array of property names.
22 */
23 props?: readonly string[]
24 }
25
26 export interface ContainerProps extends NodeProps {
27 nodes?: readonly (ChildProps | Node)[]
28 }
29
30 /**
31 * All types that can be passed into container methods to create or add a new
32 * child node.
33 */
34 export type NewChild =
35 | ChildProps
36 | Node
37 | readonly ChildProps[]
38 | readonly Node[]
39 | readonly string[]
40 | string
41 | undefined
42
43 // eslint-disable-next-line @typescript-eslint/no-use-before-define
44 export { Container_ as default }
45}
46
47/**
48 * The `Root`, `AtRule`, and `Rule` container nodes
49 * inherit some common methods to help work with their children.
50 *
51 * Note that all containers can store any content. If you write a rule inside
52 * a rule, PostCSS will parse it.
53 */
54declare abstract class Container_<Child extends Node = ChildNode> extends Node {
55 /**
56 * An array containing the container’s children.
57 *
58 * ```js
59 * const root = postcss.parse('a { color: black }')
60 * root.nodes.length //=> 1
61 * root.nodes[0].selector //=> 'a'
62 * root.nodes[0].nodes[0].prop //=> 'color'
63 * ```
64 */
65 nodes: Child[] | undefined
66
67 /**
68 * An internal method that converts a {@link NewChild} into a list of actual
69 * child nodes that can then be added to this container.
70 *
71 * This ensures that the nodes' parent is set to this container, that they use
72 * the correct prototype chain, and that they're marked as dirty.
73 *
74 * @param mnodes The new node or nodes to add.
75 * @param sample A node from whose raws the new node's `before` raw should be
76 * taken.
77 * @param type This should be set to `'prepend'` if the new nodes will be
78 * inserted at the beginning of the container.
79 * @hidden
80 */
81 protected normalize(
82 nodes: Container.NewChild,
83 sample: Node | undefined,
84 type?: 'prepend' | false
85 ): Child[]
86
87 /**
88 * Inserts new nodes to the end of the container.
89 *
90 * ```js
91 * const decl1 = new Declaration({ prop: 'color', value: 'black' })
92 * const decl2 = new Declaration({ prop: 'background-color', value: 'white' })
93 * rule.append(decl1, decl2)
94 *
95 * root.append({ name: 'charset', params: '"UTF-8"' }) // at-rule
96 * root.append({ selector: 'a' }) // rule
97 * rule.append({ prop: 'color', value: 'black' }) // declaration
98 * rule.append({ text: 'Comment' }) // comment
99 *
100 * root.append('a {}')
101 * root.first.append('color: black; z-index: 1')
102 * ```
103 *
104 * @param nodes New nodes.
105 * @return This node for methods chain.
106 */
107 append(...nodes: Container.NewChild[]): this
108 assign(overrides: Container.ContainerProps | object): this
109 clone(overrides?: Partial<Container.ContainerProps>): this
110 cloneAfter(overrides?: Partial<Container.ContainerProps>): this
111
112 cloneBefore(overrides?: Partial<Container.ContainerProps>): this
113
114 /**
115 * Iterates through the container’s immediate children,
116 * calling `callback` for each child.
117 *
118 * Returning `false` in the callback will break iteration.
119 *
120 * This method only iterates through the container’s immediate children.
121 * If you need to recursively iterate through all the container’s descendant
122 * nodes, use `Container#walk`.
123 *
124 * Unlike the for `{}`-cycle or `Array#forEach` this iterator is safe
125 * if you are mutating the array of child nodes during iteration.
126 * PostCSS will adjust the current index to match the mutations.
127 *
128 * ```js
129 * const root = postcss.parse('a { color: black; z-index: 1 }')
130 * const rule = root.first
131 *
132 * for (const decl of rule.nodes) {
133 * decl.cloneBefore({ prop: '-webkit-' + decl.prop })
134 * // Cycle will be infinite, because cloneBefore moves the current node
135 * // to the next index
136 * }
137 *
138 * rule.each(decl => {
139 * decl.cloneBefore({ prop: '-webkit-' + decl.prop })
140 * // Will be executed only for color and z-index
141 * })
142 * ```
143 *
144 * @param callback Iterator receives each node and index.
145 * @return Returns `false` if iteration was broke.
146 */
147 each(
148 callback: (node: Child, index: number) => false | void
149 ): false | undefined
150 /**
151 * Returns `true` if callback returns `true`
152 * for all of the container’s children.
153 *
154 * ```js
155 * const noPrefixes = rule.every(i => i.prop[0] !== '-')
156 * ```
157 *
158 * @param condition Iterator returns true or false.
159 * @return Is every child pass condition.
160 */
161 every(
162 condition: (node: Child, index: number, nodes: Child[]) => boolean
163 ): boolean
164
165 /**
166 * Returns a `child`’s index within the `Container#nodes` array.
167 *
168 * ```js
169 * rule.index( rule.nodes[2] ) //=> 2
170 * ```
171 *
172 * @param child Child of the current container.
173 * @return Child index.
174 */
175 index(child: Child | number): number
176 /**
177 * Insert new node after old node within the container.
178 *
179 * @param oldNode Child or child’s index.
180 * @param newNode New node.
181 * @return This node for methods chain.
182 */
183 insertAfter(oldNode: Child | number, newNode: Container.NewChild): this
184
185 /**
186 * Insert new node before old node within the container.
187 *
188 * ```js
189 * rule.insertBefore(decl, decl.clone({ prop: '-webkit-' + decl.prop }))
190 * ```
191 *
192 * @param oldNode Child or child’s index.
193 * @param newNode New node.
194 * @return This node for methods chain.
195 */
196 insertBefore(oldNode: Child | number, newNode: Container.NewChild): this
197
198 /**
199 * Traverses the container’s descendant nodes, calling callback
200 * for each comment node.
201 *
202 * Like `Container#each`, this method is safe
203 * to use if you are mutating arrays during iteration.
204 *
205 * ```js
206 * root.walkComments(comment => {
207 * comment.remove()
208 * })
209 * ```
210 *
211 * @param callback Iterator receives each node and index.
212 * @return Returns `false` if iteration was broke.
213 */
214
215 /**
216 * Inserts new nodes to the start of the container.
217 *
218 * ```js
219 * const decl1 = new Declaration({ prop: 'color', value: 'black' })
220 * const decl2 = new Declaration({ prop: 'background-color', value: 'white' })
221 * rule.prepend(decl1, decl2)
222 *
223 * root.append({ name: 'charset', params: '"UTF-8"' }) // at-rule
224 * root.append({ selector: 'a' }) // rule
225 * rule.append({ prop: 'color', value: 'black' }) // declaration
226 * rule.append({ text: 'Comment' }) // comment
227 *
228 * root.append('a {}')
229 * root.first.append('color: black; z-index: 1')
230 * ```
231 *
232 * @param nodes New nodes.
233 * @return This node for methods chain.
234 */
235 prepend(...nodes: Container.NewChild[]): this
236 /**
237 * Add child to the end of the node.
238 *
239 * ```js
240 * rule.push(new Declaration({ prop: 'color', value: 'black' }))
241 * ```
242 *
243 * @param child New node.
244 * @return This node for methods chain.
245 */
246 push(child: Child): this
247
248 /**
249 * Removes all children from the container
250 * and cleans their parent properties.
251 *
252 * ```js
253 * rule.removeAll()
254 * rule.nodes.length //=> 0
255 * ```
256 *
257 * @return This node for methods chain.
258 */
259 removeAll(): this
260
261 /**
262 * Removes node from the container and cleans the parent properties
263 * from the node and its children.
264 *
265 * ```js
266 * rule.nodes.length //=> 5
267 * rule.removeChild(decl)
268 * rule.nodes.length //=> 4
269 * decl.parent //=> undefined
270 * ```
271 *
272 * @param child Child or child’s index.
273 * @return This node for methods chain.
274 */
275 removeChild(child: Child | number): this
276
277 replaceValues(
278 pattern: RegExp | string,
279 replaced: { (substring: string, ...args: any[]): string } | string
280 ): this
281
282 /**
283 * Passes all declaration values within the container that match pattern
284 * through callback, replacing those values with the returned result
285 * of callback.
286 *
287 * This method is useful if you are using a custom unit or function
288 * and need to iterate through all values.
289 *
290 * ```js
291 * root.replaceValues(/\d+rem/, { fast: 'rem' }, string => {
292 * return 15 * parseInt(string) + 'px'
293 * })
294 * ```
295 *
296 * @param pattern Replace pattern.
297 * @param {object} options Options to speed up the search.
298 * @param replaced String to replace pattern or callback
299 * that returns a new value. The callback
300 * will receive the same arguments
301 * as those passed to a function parameter
302 * of `String#replace`.
303 * @return This node for methods chain.
304 */
305 replaceValues(
306 pattern: RegExp | string,
307 options: Container.ValueOptions,
308 replaced: { (substring: string, ...args: any[]): string } | string
309 ): this
310
311 /**
312 * Returns `true` if callback returns `true` for (at least) one
313 * of the container’s children.
314 *
315 * ```js
316 * const hasPrefix = rule.some(i => i.prop[0] === '-')
317 * ```
318 *
319 * @param condition Iterator returns true or false.
320 * @return Is some child pass condition.
321 */
322 some(
323 condition: (node: Child, index: number, nodes: Child[]) => boolean
324 ): boolean
325
326 /**
327 * Traverses the container’s descendant nodes, calling callback
328 * for each node.
329 *
330 * Like container.each(), this method is safe to use
331 * if you are mutating arrays during iteration.
332 *
333 * If you only need to iterate through the container’s immediate children,
334 * use `Container#each`.
335 *
336 * ```js
337 * root.walk(node => {
338 * // Traverses all descendant nodes.
339 * })
340 * ```
341 *
342 * @param callback Iterator receives each node and index.
343 * @return Returns `false` if iteration was broke.
344 */
345 walk(
346 callback: (node: ChildNode, index: number) => false | void
347 ): false | undefined
348
349 /**
350 * Traverses the container’s descendant nodes, calling callback
351 * for each at-rule node.
352 *
353 * If you pass a filter, iteration will only happen over at-rules
354 * that have matching names.
355 *
356 * Like `Container#each`, this method is safe
357 * to use if you are mutating arrays during iteration.
358 *
359 * ```js
360 * root.walkAtRules(rule => {
361 * if (isOld(rule.name)) rule.remove()
362 * })
363 *
364 * let first = false
365 * root.walkAtRules('charset', rule => {
366 * if (!first) {
367 * first = true
368 * } else {
369 * rule.remove()
370 * }
371 * })
372 * ```
373 *
374 * @param name String or regular expression to filter at-rules by name.
375 * @param callback Iterator receives each node and index.
376 * @return Returns `false` if iteration was broke.
377 */
378 walkAtRules(
379 nameFilter: RegExp | string,
380 callback: (atRule: AtRule, index: number) => false | void
381 ): false | undefined
382
383 walkAtRules(
384 callback: (atRule: AtRule, index: number) => false | void
385 ): false | undefined
386 walkComments(
387 callback: (comment: Comment, indexed: number) => false | void
388 ): false | undefined
389
390 walkComments(
391 callback: (comment: Comment, indexed: number) => false | void
392 ): false | undefined
393
394 /**
395 * Traverses the container’s descendant nodes, calling callback
396 * for each declaration node.
397 *
398 * If you pass a filter, iteration will only happen over declarations
399 * with matching properties.
400 *
401 * ```js
402 * root.walkDecls(decl => {
403 * checkPropertySupport(decl.prop)
404 * })
405 *
406 * root.walkDecls('border-radius', decl => {
407 * decl.remove()
408 * })
409 *
410 * root.walkDecls(/^background/, decl => {
411 * decl.value = takeFirstColorFromGradient(decl.value)
412 * })
413 * ```
414 *
415 * Like `Container#each`, this method is safe
416 * to use if you are mutating arrays during iteration.
417 *
418 * @param prop String or regular expression to filter declarations
419 * by property name.
420 * @param callback Iterator receives each node and index.
421 * @return Returns `false` if iteration was broke.
422 */
423 walkDecls(
424 propFilter: RegExp | string,
425 callback: (decl: Declaration, index: number) => false | void
426 ): false | undefined
427
428 walkDecls(
429 callback: (decl: Declaration, index: number) => false | void
430 ): false | undefined
431
432 /**
433 * Traverses the container’s descendant nodes, calling callback
434 * for each rule node.
435 *
436 * If you pass a filter, iteration will only happen over rules
437 * with matching selectors.
438 *
439 * Like `Container#each`, this method is safe
440 * to use if you are mutating arrays during iteration.
441 *
442 * ```js
443 * const selectors = []
444 * root.walkRules(rule => {
445 * selectors.push(rule.selector)
446 * })
447 * console.log(`Your CSS uses ${ selectors.length } selectors`)
448 * ```
449 *
450 * @param selector String or regular expression to filter rules by selector.
451 * @param callback Iterator receives each node and index.
452 * @return Returns `false` if iteration was broke.
453 */
454 walkRules(
455 selectorFilter: RegExp | string,
456 callback: (rule: Rule, index: number) => false | void
457 ): false | undefined
458 walkRules(
459 callback: (rule: Rule, index: number) => false | void
460 ): false | undefined
461 /**
462 * The container’s first child.
463 *
464 * ```js
465 * rule.first === rules.nodes[0]
466 * ```
467 */
468 get first(): Child | undefined
469 /**
470 * The container’s last child.
471 *
472 * ```js
473 * rule.last === rule.nodes[rule.nodes.length - 1]
474 * ```
475 */
476 get last(): Child | undefined
477}
478
479declare class Container<
480 Child extends Node = ChildNode
481> extends Container_<Child> {}
482
483export = Container
Note: See TracBrowser for help on using the repository browser.