@libs-ui/components-inputs-quill 0.1.1-1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,429 @@
1
+ import { signal } from '@angular/core';
2
+ import { returnListObject } from '@libs-ui/services-http-request';
3
+ import { convertFileToBase64_ObjectUrl } from '@libs-ui/utils';
4
+ export const listDataAlign = () => {
5
+ return [
6
+ { key: '', icon: 'libs-ui-icon-align-left text-[#6a7383] text-[16px] hover:text-[var(--libs-ui-color-light-1)]' },
7
+ { key: 'right', icon: 'libs-ui-icon-align-right text-[#6a7383] text-[16px] hover:text-[var(--libs-ui-color-light-1)]' },
8
+ { key: 'center', icon: 'libs-ui-icon-align-center text-[#6a7383] text-[16px] hover:text-[var(--libs-ui-color-light-1)]' },
9
+ { key: 'justify', icon: 'libs-ui-icon-align-justify text-[#6a7383] text-[16px] hover:text-[var(--libs-ui-color-light-1)]' },
10
+ ];
11
+ };
12
+ export const listFont = () => {
13
+ return [
14
+ { key: '', label: 'Sans Serif' },
15
+ { key: 'serif', label: 'Serif' },
16
+ { key: 'monospace', label: 'Monospace' },
17
+ ];
18
+ };
19
+ export const listHeader = () => {
20
+ return [
21
+ { key: '', label: 'Normal' },
22
+ { key: '1', label: 'Heading 1' },
23
+ { key: '2', label: 'Heading 2' },
24
+ { key: '3', label: 'Heading 3' },
25
+ { key: '4', label: 'Heading 4' },
26
+ { key: '5', label: 'Heading 5' },
27
+ { key: '6', label: 'Heading 6' },
28
+ ];
29
+ };
30
+ export const listConfigAlign = () => {
31
+ return {
32
+ type: 'text',
33
+ autoSelectFirstItem: true,
34
+ httpRequestData: signal({
35
+ objectInstance: returnListObject(listDataAlign()),
36
+ functionName: 'list',
37
+ argumentsValue: [],
38
+ }),
39
+ configTemplateText: signal({
40
+ fieldKey: 'key',
41
+ getClassItem: () => '!px-[8px] !py-[4px]',
42
+ getValue: (item) => `<i class='flex ${item.icon}'></i>`,
43
+ ignoreIconSelected: true,
44
+ }),
45
+ };
46
+ };
47
+ export const listConfigFont = () => {
48
+ return {
49
+ type: 'text',
50
+ autoSelectFirstItem: true,
51
+ httpRequestData: signal({
52
+ objectInstance: returnListObject(listFont()),
53
+ functionName: 'list',
54
+ argumentsValue: [],
55
+ }),
56
+ configTemplateText: signal({
57
+ fieldKey: 'key',
58
+ getValue: (item) => item.label,
59
+ ignoreIconSelected: true,
60
+ }),
61
+ };
62
+ };
63
+ export const listConfigHeader = () => {
64
+ return {
65
+ type: 'text',
66
+ autoSelectFirstItem: true,
67
+ httpRequestData: signal({
68
+ objectInstance: returnListObject(listHeader()),
69
+ functionName: 'list',
70
+ argumentsValue: [],
71
+ }),
72
+ configTemplateText: signal({
73
+ fieldKey: 'key',
74
+ getValue: (item) => item.label,
75
+ ignoreIconSelected: true,
76
+ }),
77
+ };
78
+ };
79
+ export const toolBarOptions = (mode, hasIconImage, hasIconPersonalize) => {
80
+ return [
81
+ {
82
+ type: 'undo',
83
+ classInclude: 'mr-[8px]',
84
+ mode: ['default', 'basic'],
85
+ width: 24,
86
+ },
87
+ {
88
+ type: 'redo',
89
+ mode: ['default', 'basic'],
90
+ width: 32,
91
+ },
92
+ {
93
+ type: 'line',
94
+ mode: ['default', 'basic'],
95
+ width: 1,
96
+ },
97
+ {
98
+ type: 'header',
99
+ classInclude: 'ml-[8px]',
100
+ mode: [],
101
+ width: 146,
102
+ },
103
+ {
104
+ type: 'fontFamily',
105
+ classInclude: 'ml-[8px]',
106
+ mode: ['default'],
107
+ width: 136,
108
+ },
109
+ {
110
+ type: 'fontSize',
111
+ classInclude: 'ml-[8px] mr-[8px]',
112
+ mode: ['default'],
113
+ width: 82,
114
+ },
115
+ {
116
+ type: 'line',
117
+ mode: ['default'],
118
+ width: 1,
119
+ },
120
+ {
121
+ type: 'color',
122
+ mode: ['default', 'basic'],
123
+ width: 32,
124
+ },
125
+ {
126
+ type: 'background',
127
+ mode: ['default'],
128
+ width: 32,
129
+ },
130
+ {
131
+ type: 'line',
132
+ mode: ['default', 'basic'],
133
+ width: 1,
134
+ },
135
+ {
136
+ type: 'bold',
137
+ mode: ['default', 'basic'],
138
+ width: 32,
139
+ },
140
+ {
141
+ type: 'italic',
142
+ mode: ['default', 'basic'],
143
+ width: 32,
144
+ },
145
+ {
146
+ type: 'underline',
147
+ mode: ['default', 'basic'],
148
+ width: 32,
149
+ },
150
+ {
151
+ type: 'strikeThrough',
152
+ mode: ['default'],
153
+ width: 32,
154
+ },
155
+ {
156
+ type: 'line',
157
+ mode: ['default', 'basic'],
158
+ width: 1,
159
+ },
160
+ {
161
+ type: 'adjust',
162
+ mode: ['default'],
163
+ width: 52,
164
+ },
165
+ {
166
+ type: 'line',
167
+ mode: ['default'],
168
+ width: 32,
169
+ },
170
+ {
171
+ type: 'indentIncrease',
172
+ mode: ['default'],
173
+ width: 32,
174
+ },
175
+ {
176
+ type: 'indentDecrease',
177
+ mode: ['default'],
178
+ width: 32,
179
+ },
180
+ {
181
+ type: 'listBulleted',
182
+ mode: ['default'],
183
+ width: 32,
184
+ },
185
+ {
186
+ type: 'listNumbered',
187
+ mode: ['default'],
188
+ width: 32,
189
+ },
190
+ {
191
+ type: 'line',
192
+ mode: ['default'],
193
+ width: 1,
194
+ },
195
+ {
196
+ type: 'personalize',
197
+ mode: ['default'],
198
+ width: 32,
199
+ },
200
+ {
201
+ type: 'blockquote',
202
+ mode: ['default'],
203
+ width: 32,
204
+ },
205
+ {
206
+ type: 'link',
207
+ mode: ['default', 'basic'],
208
+ width: 32,
209
+ },
210
+ {
211
+ type: 'unLink',
212
+ mode: ['default', 'basic'],
213
+ width: 32,
214
+ },
215
+ {
216
+ type: 'image',
217
+ mode: ['default'],
218
+ width: 32,
219
+ },
220
+ {
221
+ type: 'emoji',
222
+ classInclude: 'ml-[8px]',
223
+ mode: ['default'],
224
+ width: 24,
225
+ },
226
+ {
227
+ type: 'insertTable',
228
+ mode: ['default'],
229
+ width: 32,
230
+ },
231
+ ].filter((item) => {
232
+ if (!item.mode?.includes(mode)) {
233
+ return false;
234
+ }
235
+ if (item.type === 'image') {
236
+ return hasIconImage;
237
+ }
238
+ if (item.type === 'personalize') {
239
+ return hasIconPersonalize;
240
+ }
241
+ return true;
242
+ });
243
+ };
244
+ export const iconList = () => {
245
+ return [
246
+ {
247
+ key: 'bold',
248
+ icon: 'libs-ui-icon-editor-bold',
249
+ },
250
+ {
251
+ key: 'italic',
252
+ icon: 'libs-ui-icon-editor-italic',
253
+ },
254
+ {
255
+ key: 'underline',
256
+ icon: 'libs-ui-icon-editor-underlined',
257
+ },
258
+ {
259
+ key: 'image',
260
+ icon: 'libs-ui-icon-image-solid',
261
+ },
262
+ {
263
+ key: 'link',
264
+ icon: 'libs-ui-icon-link',
265
+ },
266
+ {
267
+ key: 'undo',
268
+ icon: 'libs-ui-icon-undo',
269
+ },
270
+ {
271
+ key: 'redo',
272
+ icon: 'libs-ui-icon-undo scale-x-[-1]',
273
+ },
274
+ {
275
+ key: 'strike',
276
+ icon: 'libs-ui-icon-editor-strike-through',
277
+ },
278
+ {
279
+ key: 'blockquote',
280
+ icon: 'libs-ui-icon-quote',
281
+ },
282
+ {
283
+ key: 'ordered',
284
+ icon: 'libs-ui-icon-list-numbered',
285
+ },
286
+ {
287
+ key: 'bullet',
288
+ icon: 'libs-ui-icon-list-bulleted',
289
+ },
290
+ {
291
+ key: 'background',
292
+ icon: 'libs-ui-icon-editor-color-background',
293
+ },
294
+ {
295
+ key: 'color',
296
+ icon: 'libs-ui-icon-editor-color-text',
297
+ },
298
+ {
299
+ key: 'indent.-1',
300
+ icon: 'libs-ui-icon-indent-decrease',
301
+ },
302
+ {
303
+ key: 'indent.+1',
304
+ icon: 'libs-ui-icon-indent-increase',
305
+ },
306
+ {
307
+ key: 'align.',
308
+ icon: 'align-quill libs-ui-icon-align-left',
309
+ },
310
+ {
311
+ key: 'align.center',
312
+ icon: 'align-quill libs-ui-icon-align-center',
313
+ },
314
+ {
315
+ key: 'align.right',
316
+ icon: 'align-quill libs-ui-icon-align-right',
317
+ },
318
+ {
319
+ key: 'align.justify',
320
+ icon: 'align-quill libs-ui-icon-align-justify',
321
+ },
322
+ {
323
+ key: 'unLink',
324
+ icon: 'libs-ui-icon-link-broken',
325
+ },
326
+ {
327
+ key: 'emoji',
328
+ icon: 'libs-ui-icon-face-smile',
329
+ },
330
+ {
331
+ key: 'insertTable',
332
+ icon: 'libs-ui-icon-face-smile',
333
+ },
334
+ ];
335
+ };
336
+ export const uploadImageConfigDefault = () => {
337
+ return {
338
+ modeCustom: false,
339
+ zIndex: 1202,
340
+ showIcon: true,
341
+ maxImageSize: 5 * 1024 * 1024,
342
+ onlyAcceptImageHttpsLink: false,
343
+ functionUploadImage: async (files) => {
344
+ const data = [];
345
+ for (const file of files) {
346
+ data.push(await convertFileToBase64_ObjectUrl(file));
347
+ }
348
+ return data;
349
+ },
350
+ };
351
+ };
352
+ export const linkDefault = () => {
353
+ return {
354
+ title: '',
355
+ url: '',
356
+ range: {
357
+ index: 0,
358
+ length: 0,
359
+ },
360
+ };
361
+ };
362
+ export const fontSizeWhiteList = () => [
363
+ '8px',
364
+ '9px',
365
+ '10px',
366
+ '11px',
367
+ '12px',
368
+ '13px',
369
+ '14px',
370
+ '15px',
371
+ '16px',
372
+ '17px',
373
+ '18px',
374
+ '19px',
375
+ '20px',
376
+ '21px',
377
+ '22px',
378
+ '23px',
379
+ '24px',
380
+ '25px',
381
+ '26px',
382
+ '27px',
383
+ '28px',
384
+ '29px',
385
+ '30px',
386
+ '31px',
387
+ '32px',
388
+ '33px',
389
+ '34px',
390
+ '35px',
391
+ '36px',
392
+ '37px',
393
+ '38px',
394
+ '39px',
395
+ '40px',
396
+ '41px',
397
+ '42px',
398
+ '43px',
399
+ '44px',
400
+ '45px',
401
+ '46px',
402
+ '47px',
403
+ '48px',
404
+ '49px',
405
+ '50px',
406
+ '51px',
407
+ '52px',
408
+ '53px',
409
+ '54px',
410
+ '55px',
411
+ '56px',
412
+ '57px',
413
+ '58px',
414
+ '59px',
415
+ '60px',
416
+ '61px',
417
+ '62px',
418
+ '63px',
419
+ '64px',
420
+ '65px',
421
+ '66px',
422
+ '67px',
423
+ '68px',
424
+ '69px',
425
+ '70px',
426
+ '71px',
427
+ '72px',
428
+ ];
429
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"quill.define.js","sourceRoot":"","sources":["../../../../../../../libs-ui/components/inputs/quill/src/utils/quill.define.ts"],"names":[],"mappings":"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,MAAM;IACN,MAAM;IACN,MAAM;IACN,MAAM;IACN,MAAM;IACN,MAAM;IACN,MAAM;IACN,MAAM;IACN,MAAM;IACN,MAAM;IACN,MAAM;IACN,MAAM;IACN,MAAM;IACN,MAAM;IACN,MAAM;IACN,MAAM;IACN,MAAM;IACN,MAAM;IACN,MAAM;IACN,MAAM;IACN,MAAM;IACN,MAAM;IACN,MAAM;IACN,MAAM;IACN,MAAM;IACN,MAAM;IACN,MAAM;IACN,MAAM;IACN,MAAM;IACN,MAAM;IACN,MAAM;IACN,MAAM;IACN,MAAM;IACN,MAAM;IACN,MAAM;IACN,MAAM;IACN,MAAM;IACN,MAAM;IACN,MAAM;IACN,MAAM;IACN,MAAM;IACN,MAAM;IACN,MAAM;IACN,MAAM;IACN,MAAM;IACN,MAAM;IACN,MAAM;IACN,MAAM;IACN,MAAM;IACN,MAAM;IACN,MAAM;IACN,MAAM;IACN,MAAM;IACN,MAAM;IACN,MAAM;IACN,MAAM;IACN,MAAM;IACN,MAAM;IACN,MAAM;IACN,MAAM;IACN,MAAM;IACN,MAAM;IACN,MAAM;CACP,CAAC","sourcesContent":["import { signal } from '@angular/core';\nimport { IListConfigItem } from '@libs-ui/components-list';\nimport { IHttpRequestConfig, returnListObject } from '@libs-ui/services-http-request';\nimport { IQuillLink, IQuillToolbarConfig, IQuillUploadImageConfig, TYPE_MODE_BAR_CONFIG_OPTION } from '../interfaces/quill.interface';\nimport { convertFileToBase64_ObjectUrl } from '@libs-ui/utils';\n\nexport const listDataAlign = () => {\n  return [\n    { key: '', icon: 'libs-ui-icon-align-left text-[#6a7383] text-[16px] hover:text-[var(--libs-ui-color-light-1)]' },\n    { key: 'right', icon: 'libs-ui-icon-align-right text-[#6a7383] text-[16px] hover:text-[var(--libs-ui-color-light-1)]' },\n    { key: 'center', icon: 'libs-ui-icon-align-center text-[#6a7383] text-[16px] hover:text-[var(--libs-ui-color-light-1)]' },\n    { key: 'justify', icon: 'libs-ui-icon-align-justify text-[#6a7383] text-[16px] hover:text-[var(--libs-ui-color-light-1)]' },\n  ];\n};\n\nexport const listFont = () => {\n  return [\n    { key: '', label: 'Sans Serif' },\n    { key: 'serif', label: 'Serif' },\n    { key: 'monospace', label: 'Monospace' },\n  ];\n};\n\nexport const listHeader = () => {\n  return [\n    { key: '', label: 'Normal' },\n    { key: '1', label: 'Heading 1' },\n    { key: '2', label: 'Heading 2' },\n    { key: '3', label: 'Heading 3' },\n    { key: '4', label: 'Heading 4' },\n    { key: '5', label: 'Heading 5' },\n    { key: '6', label: 'Heading 6' },\n  ];\n};\n\nexport const listConfigAlign = (): IListConfigItem => {\n  return {\n    type: 'text',\n    autoSelectFirstItem: true,\n    httpRequestData: signal<IHttpRequestConfig>({\n      objectInstance: returnListObject(listDataAlign()),\n      functionName: 'list',\n      argumentsValue: [],\n    }),\n    configTemplateText: signal({\n      fieldKey: 'key',\n      getClassItem: () => '!px-[8px] !py-[4px]',\n      getValue: (item) => `<i class='flex ${item.icon}'></i>`,\n      ignoreIconSelected: true,\n    }),\n  };\n};\n\nexport const listConfigFont = (): IListConfigItem => {\n  return {\n    type: 'text',\n    autoSelectFirstItem: true,\n    httpRequestData: signal<IHttpRequestConfig>({\n      objectInstance: returnListObject(listFont()),\n      functionName: 'list',\n      argumentsValue: [],\n    }),\n    configTemplateText: signal({\n      fieldKey: 'key',\n      getValue: (item) => item.label,\n      ignoreIconSelected: true,\n    }),\n  };\n};\n\nexport const listConfigHeader = (): IListConfigItem => {\n  return {\n    type: 'text',\n    autoSelectFirstItem: true,\n    httpRequestData: signal<IHttpRequestConfig>({\n      objectInstance: returnListObject(listHeader()),\n      functionName: 'list',\n      argumentsValue: [],\n    }),\n    configTemplateText: signal({\n      fieldKey: 'key',\n      getValue: (item) => item.label,\n      ignoreIconSelected: true,\n    }),\n  };\n};\n\nexport const toolBarOptions = (mode: TYPE_MODE_BAR_CONFIG_OPTION, hasIconImage: boolean, hasIconPersonalize: boolean): Array<IQuillToolbarConfig> => {\n  return (\n    [\n      {\n        type: 'undo',\n        classInclude: 'mr-[8px]',\n        mode: ['default', 'basic'],\n        width: 24,\n      },\n      {\n        type: 'redo',\n        mode: ['default', 'basic'],\n        width: 32,\n      },\n      {\n        type: 'line',\n        mode: ['default', 'basic'],\n        width: 1,\n      },\n      {\n        type: 'header',\n        classInclude: 'ml-[8px]',\n        mode: [],\n        width: 146,\n      },\n      {\n        type: 'fontFamily',\n        classInclude: 'ml-[8px]',\n        mode: ['default'],\n        width: 136,\n      },\n      {\n        type: 'fontSize',\n        classInclude: 'ml-[8px] mr-[8px]',\n        mode: ['default'],\n        width: 82,\n      },\n      {\n        type: 'line',\n        mode: ['default'],\n        width: 1,\n      },\n      {\n        type: 'color',\n        mode: ['default', 'basic'],\n        width: 32,\n      },\n      {\n        type: 'background',\n        mode: ['default'],\n        width: 32,\n      },\n      {\n        type: 'line',\n        mode: ['default', 'basic'],\n        width: 1,\n      },\n      {\n        type: 'bold',\n        mode: ['default', 'basic'],\n        width: 32,\n      },\n      {\n        type: 'italic',\n        mode: ['default', 'basic'],\n        width: 32,\n      },\n      {\n        type: 'underline',\n        mode: ['default', 'basic'],\n        width: 32,\n      },\n      {\n        type: 'strikeThrough',\n        mode: ['default'],\n        width: 32,\n      },\n      {\n        type: 'line',\n        mode: ['default', 'basic'],\n        width: 1,\n      },\n      {\n        type: 'adjust',\n        mode: ['default'],\n        width: 52,\n      },\n      {\n        type: 'line',\n        mode: ['default'],\n        width: 32,\n      },\n      {\n        type: 'indentIncrease',\n        mode: ['default'],\n        width: 32,\n      },\n      {\n        type: 'indentDecrease',\n        mode: ['default'],\n        width: 32,\n      },\n      {\n        type: 'listBulleted',\n        mode: ['default'],\n        width: 32,\n      },\n      {\n        type: 'listNumbered',\n        mode: ['default'],\n        width: 32,\n      },\n      {\n        type: 'line',\n        mode: ['default'],\n        width: 1,\n      },\n      {\n        type: 'personalize',\n        mode: ['default'],\n        width: 32,\n      },\n      {\n        type: 'blockquote',\n        mode: ['default'],\n        width: 32,\n      },\n      {\n        type: 'link',\n        mode: ['default', 'basic'],\n        width: 32,\n      },\n      {\n        type: 'unLink',\n        mode: ['default', 'basic'],\n        width: 32,\n      },\n      {\n        type: 'image',\n        mode: ['default'],\n        width: 32,\n      },\n      {\n        type: 'emoji',\n        classInclude: 'ml-[8px]',\n        mode: ['default'],\n        width: 24,\n      },\n      {\n        type: 'insertTable',\n        mode: ['default'],\n        width: 32,\n      },\n    ] as Array<IQuillToolbarConfig>\n  ).filter((item) => {\n    if (!item.mode?.includes(mode)) {\n      return false;\n    }\n    if (item.type === 'image') {\n      return hasIconImage;\n    }\n    if (item.type === 'personalize') {\n      return hasIconPersonalize;\n    }\n\n    return true;\n  });\n};\nexport const iconList = (): Array<{ key: string; icon: string }> => {\n  return [\n    {\n      key: 'bold',\n      icon: 'libs-ui-icon-editor-bold',\n    },\n    {\n      key: 'italic',\n      icon: 'libs-ui-icon-editor-italic',\n    },\n    {\n      key: 'underline',\n      icon: 'libs-ui-icon-editor-underlined',\n    },\n    {\n      key: 'image',\n      icon: 'libs-ui-icon-image-solid',\n    },\n    {\n      key: 'link',\n      icon: 'libs-ui-icon-link',\n    },\n    {\n      key: 'undo',\n      icon: 'libs-ui-icon-undo',\n    },\n    {\n      key: 'redo',\n      icon: 'libs-ui-icon-undo scale-x-[-1]',\n    },\n    {\n      key: 'strike',\n      icon: 'libs-ui-icon-editor-strike-through',\n    },\n    {\n      key: 'blockquote',\n      icon: 'libs-ui-icon-quote',\n    },\n    {\n      key: 'ordered',\n      icon: 'libs-ui-icon-list-numbered',\n    },\n    {\n      key: 'bullet',\n      icon: 'libs-ui-icon-list-bulleted',\n    },\n    {\n      key: 'background',\n      icon: 'libs-ui-icon-editor-color-background',\n    },\n    {\n      key: 'color',\n      icon: 'libs-ui-icon-editor-color-text',\n    },\n    {\n      key: 'indent.-1',\n      icon: 'libs-ui-icon-indent-decrease',\n    },\n    {\n      key: 'indent.+1',\n      icon: 'libs-ui-icon-indent-increase',\n    },\n    {\n      key: 'align.',\n      icon: 'align-quill libs-ui-icon-align-left',\n    },\n    {\n      key: 'align.center',\n      icon: 'align-quill libs-ui-icon-align-center',\n    },\n    {\n      key: 'align.right',\n      icon: 'align-quill libs-ui-icon-align-right',\n    },\n    {\n      key: 'align.justify',\n      icon: 'align-quill libs-ui-icon-align-justify',\n    },\n    {\n      key: 'unLink',\n      icon: 'libs-ui-icon-link-broken',\n    },\n    {\n      key: 'emoji',\n      icon: 'libs-ui-icon-face-smile',\n    },\n    {\n      key: 'insertTable',\n      icon: 'libs-ui-icon-face-smile',\n    },\n  ];\n};\n\nexport const uploadImageConfigDefault = (): IQuillUploadImageConfig => {\n  return {\n    modeCustom: false,\n    zIndex: 1202,\n    showIcon: true,\n    maxImageSize: 5 * 1024 * 1024,\n    onlyAcceptImageHttpsLink: false,\n    functionUploadImage: async (files: Array<File>) => {\n      const data = [];\n      for (const file of files) {\n        data.push(await convertFileToBase64_ObjectUrl(file));\n      }\n      return data;\n    },\n  };\n};\n\nexport const linkDefault = (): IQuillLink => {\n  return {\n    title: '',\n    url: '',\n    range: {\n      index: 0,\n      length: 0,\n    },\n  };\n};\n\nexport const fontSizeWhiteList = () => [\n  '8px',\n  '9px',\n  '10px',\n  '11px',\n  '12px',\n  '13px',\n  '14px',\n  '15px',\n  '16px',\n  '17px',\n  '18px',\n  '19px',\n  '20px',\n  '21px',\n  '22px',\n  '23px',\n  '24px',\n  '25px',\n  '26px',\n  '27px',\n  '28px',\n  '29px',\n  '30px',\n  '31px',\n  '32px',\n  '33px',\n  '34px',\n  '35px',\n  '36px',\n  '37px',\n  '38px',\n  '39px',\n  '40px',\n  '41px',\n  '42px',\n  '43px',\n  '44px',\n  '45px',\n  '46px',\n  '47px',\n  '48px',\n  '49px',\n  '50px',\n  '51px',\n  '52px',\n  '53px',\n  '54px',\n  '55px',\n  '56px',\n  '57px',\n  '58px',\n  '59px',\n  '60px',\n  '61px',\n  '62px',\n  '63px',\n  '64px',\n  '65px',\n  '66px',\n  '67px',\n  '68px',\n  '69px',\n  '70px',\n  '71px',\n  '72px',\n];\n"]}