@taiga-ui/cdk 5.2.0 → 5.3.0
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.
- package/constants/version.d.ts +1 -1
- package/constants/version.js +1 -1
- package/fesm2022/taiga-ui-cdk-constants.mjs +1 -1
- package/fesm2022/taiga-ui-cdk-constants.mjs.map +1 -1
- package/fesm2022/taiga-ui-cdk-directives-truncate.mjs +3 -3
- package/fesm2022/taiga-ui-cdk-utils-dom.mjs +6 -1
- package/fesm2022/taiga-ui-cdk-utils-dom.mjs.map +1 -1
- package/package.json +1 -1
- package/schematics/ng-add/constants/versions.d.ts +1 -1
- package/schematics/ng-update/utils/templates/remove-attr.d.ts +14 -0
- package/schematics/ng-update/utils/templates/remove-attr.js +28 -0
- package/schematics/ng-update/utils/templates/remove-attr.js.map +1 -0
- package/schematics/ng-update/v5/steps/constants/attr-with-values-to-replace.js +14 -0
- package/schematics/ng-update/v5/steps/constants/attr-with-values-to-replace.js.map +1 -1
- package/schematics/ng-update/v5/steps/constants/attrs-to-replace.js +8 -16
- package/schematics/ng-update/v5/steps/constants/attrs-to-replace.js.map +1 -1
- package/schematics/ng-update/v5/steps/constants/html-comments.js +5 -5
- package/schematics/ng-update/v5/steps/constants/html-comments.js.map +1 -1
- package/schematics/ng-update/v5/steps/constants/identifiers-to-replace.js +11 -30
- package/schematics/ng-update/v5/steps/constants/identifiers-to-replace.js.map +1 -1
- package/schematics/ng-update/v5/steps/constants/inputs-to-remove.js +4 -0
- package/schematics/ng-update/v5/steps/constants/inputs-to-remove.js.map +1 -1
- package/schematics/ng-update/v5/steps/constants/migration-warnings.js +5 -5
- package/schematics/ng-update/v5/steps/constants/migration-warnings.js.map +1 -1
- package/schematics/ng-update/v5/steps/constants/modules-to-remove.js +0 -4
- package/schematics/ng-update/v5/steps/constants/modules-to-remove.js.map +1 -1
- package/schematics/ng-update/v5/steps/constants/tags-to-replace.js +0 -5
- package/schematics/ng-update/v5/steps/constants/tags-to-replace.js.map +1 -1
- package/schematics/ng-update/v5/steps/migrate-doc-i18n-tokens.js +2 -1
- package/schematics/ng-update/v5/steps/migrate-doc-i18n-tokens.js.map +1 -1
- package/schematics/ng-update/v5/steps/migrate-portals.js +1 -4
- package/schematics/ng-update/v5/steps/migrate-portals.js.map +1 -1
- package/schematics/ng-update/v5/steps/migrate-templates.js +4 -3
- package/schematics/ng-update/v5/steps/migrate-templates.js.map +1 -1
- package/schematics/ng-update/v5/steps/migrate-tokens/migrate-tokens.js +2 -1
- package/schematics/ng-update/v5/steps/migrate-tokens/migrate-tokens.js.map +1 -1
- package/schematics/ng-update/v5/steps/migrate-tui-let.js +0 -2
- package/schematics/ng-update/v5/steps/migrate-tui-let.js.map +1 -1
- package/schematics/ng-update/v5/steps/templates/migrate-amount-currency-align.js +3 -2
- package/schematics/ng-update/v5/steps/templates/migrate-amount-currency-align.js.map +1 -1
- package/schematics/ng-update/v5/steps/templates/migrate-combo-box.js +54 -21
- package/schematics/ng-update/v5/steps/templates/migrate-combo-box.js.map +1 -1
- package/schematics/ng-update/v5/steps/templates/{migrate-proprietary-textfield-icons.d.ts → migrate-doc-documentation.d.ts} +2 -2
- package/schematics/ng-update/v5/steps/templates/migrate-doc-documentation.js +207 -0
- package/schematics/ng-update/v5/steps/templates/migrate-doc-documentation.js.map +1 -0
- package/schematics/ng-update/v5/steps/templates/migrate-hint-on-legacy-controls.js +2 -0
- package/schematics/ng-update/v5/steps/templates/migrate-hint-on-legacy-controls.js.map +1 -1
- package/schematics/ng-update/v5/steps/templates/migrate-input-color.js +22 -6
- package/schematics/ng-update/v5/steps/templates/migrate-input-color.js.map +1 -1
- package/schematics/ng-update/v5/steps/templates/migrate-input-date-multi.js +23 -7
- package/schematics/ng-update/v5/steps/templates/migrate-input-date-multi.js.map +1 -1
- package/schematics/ng-update/v5/steps/templates/migrate-input-date-range.js +23 -6
- package/schematics/ng-update/v5/steps/templates/migrate-input-date-range.js.map +1 -1
- package/schematics/ng-update/v5/steps/templates/migrate-input-date.js +23 -7
- package/schematics/ng-update/v5/steps/templates/migrate-input-date.js.map +1 -1
- package/schematics/ng-update/v5/steps/templates/migrate-input-month.js +23 -6
- package/schematics/ng-update/v5/steps/templates/migrate-input-month.js.map +1 -1
- package/schematics/ng-update/v5/steps/templates/migrate-input-password.js +35 -6
- package/schematics/ng-update/v5/steps/templates/migrate-input-password.js.map +1 -1
- package/schematics/ng-update/v5/steps/templates/migrate-input-phone-international.js +23 -6
- package/schematics/ng-update/v5/steps/templates/migrate-input-phone-international.js.map +1 -1
- package/schematics/ng-update/v5/steps/templates/migrate-input-phone.js +25 -7
- package/schematics/ng-update/v5/steps/templates/migrate-input-phone.js.map +1 -1
- package/schematics/ng-update/v5/steps/templates/migrate-input-tag.js +22 -6
- package/schematics/ng-update/v5/steps/templates/migrate-input-tag.js.map +1 -1
- package/schematics/ng-update/v5/steps/templates/migrate-input-time.js +24 -8
- package/schematics/ng-update/v5/steps/templates/migrate-input-time.js.map +1 -1
- package/schematics/ng-update/v5/steps/templates/migrate-input-year.js +23 -6
- package/schematics/ng-update/v5/steps/templates/migrate-input-year.js.map +1 -1
- package/schematics/ng-update/v5/steps/templates/migrate-input.js +33 -16
- package/schematics/ng-update/v5/steps/templates/migrate-input.js.map +1 -1
- package/schematics/ng-update/v5/steps/templates/migrate-legacy-custom-content.d.ts +20 -0
- package/schematics/ng-update/v5/steps/templates/migrate-legacy-custom-content.js +125 -0
- package/schematics/ng-update/v5/steps/templates/migrate-legacy-custom-content.js.map +1 -0
- package/schematics/ng-update/v5/steps/templates/migrate-multi-select.js +4 -15
- package/schematics/ng-update/v5/steps/templates/migrate-multi-select.js.map +1 -1
- package/schematics/ng-update/v5/steps/templates/migrate-select.js +65 -24
- package/schematics/ng-update/v5/steps/templates/migrate-select.js.map +1 -1
- package/schematics/ng-update/v5/steps/templates/migrate-textarea.js +25 -18
- package/schematics/ng-update/v5/steps/templates/migrate-textarea.js.map +1 -1
- package/schematics/ng-update/v5/steps/templates/migrate-proprietary-textfield-icons.js +0 -39
- package/schematics/ng-update/v5/steps/templates/migrate-proprietary-textfield-icons.js.map +0 -1
|
@@ -4,6 +4,7 @@ exports.migrateInputDate = migrateInputDate;
|
|
|
4
4
|
const insert_todo_1 = require("../../../../utils/insert-todo");
|
|
5
5
|
const elements_1 = require("../../../../utils/templates/elements");
|
|
6
6
|
const template_resource_1 = require("../../../../utils/templates/template-resource");
|
|
7
|
+
const remove_attr_1 = require("../../../utils/templates/remove-attr");
|
|
7
8
|
const replace_tag_1 = require("../../../utils/templates/replace-tag");
|
|
8
9
|
const DOCS_LINK = 'https://taiga-ui.dev/components/input-date';
|
|
9
10
|
const INPUT_ATTRS = new Set([
|
|
@@ -24,13 +25,16 @@ function migrateInputDate({ resource, recorder, fileSystem, }) {
|
|
|
24
25
|
const templateOffset = (0, template_resource_1.getTemplateOffset)(resource);
|
|
25
26
|
const elements = (0, elements_1.findElementsByTagName)(template, 'tui-input-date');
|
|
26
27
|
elements.forEach((element) => {
|
|
27
|
-
var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k;
|
|
28
|
+
var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l;
|
|
28
29
|
// Skip `multiple` — handled by migrateInputDateMulti
|
|
29
30
|
if (element.attrs.some((attr) => attr.name === 'multiple')) {
|
|
30
31
|
return;
|
|
31
32
|
}
|
|
32
33
|
const sourceCodeLocation = element.sourceCodeLocation;
|
|
33
34
|
(0, replace_tag_1.replaceTag)(recorder, sourceCodeLocation, 'tui-input-date', 'tui-textfield', template, templateOffset);
|
|
35
|
+
const { value: labelOutside, isBinding: labelOutsideIsBinding } = (0, remove_attr_1.removeAttr)(element, 'tuiTextfieldLabelOutside', recorder, templateOffset);
|
|
36
|
+
const isLabelOutsideTrue = labelOutside === 'true' || (!labelOutsideIsBinding && labelOutside === '');
|
|
37
|
+
const isDynamic = labelOutside !== null && !isLabelOutsideTrue && labelOutside !== 'false';
|
|
34
38
|
const controlAttrs = [...element.attrs].filter((attr) => /formcontrol|ngmodel/.exec(attr.name.toLocaleLowerCase()));
|
|
35
39
|
const inputAttrs = [...element.attrs].filter((attr) => INPUT_ATTRS.has(attr.name.toLowerCase()));
|
|
36
40
|
const calendarAttrs = [...element.attrs].filter((attr) => CALENDAR_ATTR_RENAMES.has(attr.name.toLowerCase()));
|
|
@@ -45,12 +49,24 @@ function migrateInputDate({ resource, recorder, fileSystem, }) {
|
|
|
45
49
|
recorder.remove(templateOffset + startOffset, endOffset - startOffset);
|
|
46
50
|
}
|
|
47
51
|
const labelIndex = element.childNodes.findIndex((node) => node.nodeName === '#text' && (node === null || node === void 0 ? void 0 : node.value.trim()));
|
|
52
|
+
let placeholderAttr = '';
|
|
48
53
|
if (labelIndex !== -1) {
|
|
49
54
|
const labelNode = element.childNodes[labelIndex];
|
|
55
|
+
const labelText = labelNode.value.trim();
|
|
50
56
|
const labelTextStart = ((_e = (_d = labelNode === null || labelNode === void 0 ? void 0 : labelNode.sourceCodeLocation) === null || _d === void 0 ? void 0 : _d.startOffset) !== null && _e !== void 0 ? _e : 0) + templateOffset;
|
|
51
57
|
const labelTextEnd = ((_g = (_f = labelNode === null || labelNode === void 0 ? void 0 : labelNode.sourceCodeLocation) === null || _f === void 0 ? void 0 : _f.endOffset) !== null && _g !== void 0 ? _g : 0) + templateOffset;
|
|
52
|
-
|
|
53
|
-
|
|
58
|
+
if (isLabelOutsideTrue) {
|
|
59
|
+
recorder.remove(labelTextStart, labelTextEnd - labelTextStart);
|
|
60
|
+
placeholderAttr = ` placeholder="${labelText}"`;
|
|
61
|
+
}
|
|
62
|
+
else if (!isDynamic) {
|
|
63
|
+
recorder.insertRight(labelTextStart, '\n<label tuiLabel>');
|
|
64
|
+
recorder.insertRight(labelTextEnd, '</label>\n');
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
if (isDynamic) {
|
|
68
|
+
const insertAt = ((_h = sourceCodeLocation === null || sourceCodeLocation === void 0 ? void 0 : sourceCodeLocation.startOffset) !== null && _h !== void 0 ? _h : 0) + templateOffset;
|
|
69
|
+
recorder.insertLeft(insertAt, `<!-- ${insert_todo_1.TODO_MARK} [tuiTextfieldLabelOutside] is dynamic — cannot be migrated automatically. Use <label tuiLabel> inside <tui-textfield> for label-outside pattern.\n-->\n`);
|
|
54
70
|
}
|
|
55
71
|
if (noEquivalentAttrs.length > 0) {
|
|
56
72
|
const todoComment = [
|
|
@@ -58,10 +74,10 @@ function migrateInputDate({ resource, recorder, fileSystem, }) {
|
|
|
58
74
|
' - [items]: TuiNamedDay type is removed in v5. Use <datalist> + <section *tuiDropdown>',
|
|
59
75
|
` for named dates. See example: ${DOCS_LINK}#datalist -->`,
|
|
60
76
|
].join('\n');
|
|
61
|
-
const insertAt = ((
|
|
77
|
+
const insertAt = ((_j = sourceCodeLocation === null || sourceCodeLocation === void 0 ? void 0 : sourceCodeLocation.startOffset) !== null && _j !== void 0 ? _j : 0) + templateOffset;
|
|
62
78
|
recorder.insertLeft(insertAt, `${todoComment}\n`);
|
|
63
79
|
}
|
|
64
|
-
const insertOffset = ((
|
|
80
|
+
const insertOffset = ((_l = (_k = sourceCodeLocation === null || sourceCodeLocation === void 0 ? void 0 : sourceCodeLocation.endTag) === null || _k === void 0 ? void 0 : _k.startOffset) !== null && _l !== void 0 ? _l : 0) + templateOffset;
|
|
65
81
|
const inputs = element.childNodes.filter((node) => node.nodeName === 'input');
|
|
66
82
|
const migrationAttrs = [...controlAttrs, ...inputAttrs].reduce((result, attr) => {
|
|
67
83
|
const name = normalizeAttrName(attr.name);
|
|
@@ -76,7 +92,7 @@ function migrateInputDate({ resource, recorder, fileSystem, }) {
|
|
|
76
92
|
recorder.insertRight(insertOffset, `\n<tui-calendar *tuiDropdown${calendarAttrStr} />\n`);
|
|
77
93
|
}
|
|
78
94
|
else {
|
|
79
|
-
recorder.insertRight(insertOffset, `\n<input tuiInputDate${migrationAttrs} />\n<tui-calendar *tuiDropdown${calendarAttrStr} />\n`);
|
|
95
|
+
recorder.insertRight(insertOffset, `\n<input tuiInputDate${migrationAttrs}${placeholderAttr} />\n<tui-calendar *tuiDropdown${calendarAttrStr} />\n`);
|
|
80
96
|
}
|
|
81
97
|
for (const input of inputs) {
|
|
82
98
|
input.attrs.forEach((attr) => {
|
|
@@ -84,7 +100,7 @@ function migrateInputDate({ resource, recorder, fileSystem, }) {
|
|
|
84
100
|
if (/^tuiTextfield$|^tuiTextfieldLegacy$/i.exec(attr.name)) {
|
|
85
101
|
const { startOffset = 0, endOffset = 0 } = (_c = (_b = (_a = input.sourceCodeLocation) === null || _a === void 0 ? void 0 : _a.attrs) === null || _b === void 0 ? void 0 : _b[attr.name]) !== null && _c !== void 0 ? _c : {};
|
|
86
102
|
recorder.remove(templateOffset + startOffset, endOffset - startOffset);
|
|
87
|
-
recorder.insertRight(templateOffset + startOffset, `tuiInputDate${migrationAttrs}`);
|
|
103
|
+
recorder.insertRight(templateOffset + startOffset, `tuiInputDate${migrationAttrs}${placeholderAttr}`);
|
|
88
104
|
}
|
|
89
105
|
});
|
|
90
106
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"migrate-input-date.js","sourceRoot":"","sources":["../../../../../../../projects/cdk/schematics/ng-update/v5/steps/templates/migrate-input-date.ts"],"names":[],"mappings":";;
|
|
1
|
+
{"version":3,"file":"migrate-input-date.js","sourceRoot":"","sources":["../../../../../../../projects/cdk/schematics/ng-update/v5/steps/templates/migrate-input-date.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,8 +1,10 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.migrateInputMonth = migrateInputMonth;
|
|
4
|
+
const insert_todo_1 = require("../../../../utils/insert-todo");
|
|
4
5
|
const elements_1 = require("../../../../utils/templates/elements");
|
|
5
6
|
const template_resource_1 = require("../../../../utils/templates/template-resource");
|
|
7
|
+
const remove_attr_1 = require("../../../utils/templates/remove-attr");
|
|
6
8
|
const replace_tag_1 = require("../../../utils/templates/replace-tag");
|
|
7
9
|
const INPUT_ATTRS = new Set([
|
|
8
10
|
'[max]'.toLowerCase(),
|
|
@@ -25,9 +27,12 @@ function migrateInputMonth({ resource, recorder, fileSystem, }) {
|
|
|
25
27
|
const templateOffset = (0, template_resource_1.getTemplateOffset)(resource);
|
|
26
28
|
const elements = (0, elements_1.findElementsByTagName)(template, 'tui-input-month');
|
|
27
29
|
elements.forEach((element) => {
|
|
28
|
-
var _a, _b, _c, _d, _e, _f, _g, _h, _j;
|
|
30
|
+
var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k;
|
|
29
31
|
const sourceCodeLocation = element.sourceCodeLocation;
|
|
30
32
|
(0, replace_tag_1.replaceTag)(recorder, sourceCodeLocation, 'tui-input-month', 'tui-textfield', template, templateOffset);
|
|
33
|
+
const { value: labelOutside, isBinding: labelOutsideIsBinding } = (0, remove_attr_1.removeAttr)(element, 'tuiTextfieldLabelOutside', recorder, templateOffset);
|
|
34
|
+
const isLabelOutsideTrue = labelOutside === 'true' || (!labelOutsideIsBinding && labelOutside === '');
|
|
35
|
+
const isDynamic = labelOutside !== null && !isLabelOutsideTrue && labelOutside !== 'false';
|
|
31
36
|
const controlAttrs = [...element.attrs].filter((attr) => /formcontrol|ngmodel/.exec(attr.name.toLocaleLowerCase()));
|
|
32
37
|
const inputAttrs = [...element.attrs].filter((attr) => INPUT_ATTRS.has(attr.name.toLowerCase()));
|
|
33
38
|
const calendarAttrs = [...element.attrs].filter((attr) => CALENDAR_ATTRS.has(attr.name.toLowerCase()));
|
|
@@ -36,14 +41,26 @@ function migrateInputMonth({ resource, recorder, fileSystem, }) {
|
|
|
36
41
|
recorder.remove(templateOffset + startOffset, endOffset - startOffset);
|
|
37
42
|
}
|
|
38
43
|
const labelIndex = element.childNodes.findIndex((node) => node.nodeName === '#text' && (node === null || node === void 0 ? void 0 : node.value.trim()));
|
|
44
|
+
let placeholderAttr = '';
|
|
39
45
|
if (labelIndex !== -1) {
|
|
40
46
|
const labelNode = element.childNodes[labelIndex];
|
|
47
|
+
const labelText = labelNode.value.trim();
|
|
41
48
|
const labelTextStart = ((_e = (_d = labelNode === null || labelNode === void 0 ? void 0 : labelNode.sourceCodeLocation) === null || _d === void 0 ? void 0 : _d.startOffset) !== null && _e !== void 0 ? _e : 0) + templateOffset;
|
|
42
49
|
const labelTextEnd = ((_g = (_f = labelNode === null || labelNode === void 0 ? void 0 : labelNode.sourceCodeLocation) === null || _f === void 0 ? void 0 : _f.endOffset) !== null && _g !== void 0 ? _g : 0) + templateOffset;
|
|
43
|
-
|
|
44
|
-
|
|
50
|
+
if (isLabelOutsideTrue) {
|
|
51
|
+
recorder.remove(labelTextStart, labelTextEnd - labelTextStart);
|
|
52
|
+
placeholderAttr = ` placeholder="${labelText}"`;
|
|
53
|
+
}
|
|
54
|
+
else if (!isDynamic) {
|
|
55
|
+
recorder.insertRight(labelTextStart, '\n<label tuiLabel>');
|
|
56
|
+
recorder.insertRight(labelTextEnd, '</label>\n');
|
|
57
|
+
}
|
|
45
58
|
}
|
|
46
|
-
|
|
59
|
+
if (isDynamic) {
|
|
60
|
+
const insertAt = ((_h = sourceCodeLocation === null || sourceCodeLocation === void 0 ? void 0 : sourceCodeLocation.startOffset) !== null && _h !== void 0 ? _h : 0) + templateOffset;
|
|
61
|
+
recorder.insertLeft(insertAt, `<!-- ${insert_todo_1.TODO_MARK} [tuiTextfieldLabelOutside] is dynamic — cannot be migrated automatically. Use <label tuiLabel> inside <tui-textfield> for label-outside pattern.\n-->\n`);
|
|
62
|
+
}
|
|
63
|
+
const insertOffset = ((_k = (_j = sourceCodeLocation === null || sourceCodeLocation === void 0 ? void 0 : sourceCodeLocation.endTag) === null || _j === void 0 ? void 0 : _j.startOffset) !== null && _k !== void 0 ? _k : 0) + templateOffset;
|
|
47
64
|
const inputs = element.childNodes.filter((node) => node.nodeName === 'input');
|
|
48
65
|
const migrationAttrs = [...controlAttrs, ...inputAttrs].reduce((result, attr) => {
|
|
49
66
|
const name = normalizeAttrName(attr.name);
|
|
@@ -58,7 +75,7 @@ function migrateInputMonth({ resource, recorder, fileSystem, }) {
|
|
|
58
75
|
recorder.insertRight(insertOffset, `\n<tui-calendar-month *tuiDropdown${calendarAttrStr} />\n`);
|
|
59
76
|
}
|
|
60
77
|
else {
|
|
61
|
-
recorder.insertRight(insertOffset, `\n<input tuiInputMonth${migrationAttrs} />\n<tui-calendar-month *tuiDropdown${calendarAttrStr} />\n`);
|
|
78
|
+
recorder.insertRight(insertOffset, `\n<input tuiInputMonth${migrationAttrs}${placeholderAttr} />\n<tui-calendar-month *tuiDropdown${calendarAttrStr} />\n`);
|
|
62
79
|
}
|
|
63
80
|
for (const input of inputs) {
|
|
64
81
|
input.attrs.forEach((attr) => {
|
|
@@ -66,7 +83,7 @@ function migrateInputMonth({ resource, recorder, fileSystem, }) {
|
|
|
66
83
|
if (/^tuiTextfield$|^tuiTextfieldLegacy$/i.exec(attr.name)) {
|
|
67
84
|
const { startOffset = 0, endOffset = 0 } = (_c = (_b = (_a = input.sourceCodeLocation) === null || _a === void 0 ? void 0 : _a.attrs) === null || _b === void 0 ? void 0 : _b[attr.name]) !== null && _c !== void 0 ? _c : {};
|
|
68
85
|
recorder.remove(templateOffset + startOffset, endOffset - startOffset);
|
|
69
|
-
recorder.insertRight(templateOffset + startOffset, `tuiInputMonth${migrationAttrs}`);
|
|
86
|
+
recorder.insertRight(templateOffset + startOffset, `tuiInputMonth${migrationAttrs}${placeholderAttr}`);
|
|
70
87
|
}
|
|
71
88
|
});
|
|
72
89
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"migrate-input-month.js","sourceRoot":"","sources":["../../../../../../../projects/cdk/schematics/ng-update/v5/steps/templates/migrate-input-month.ts"],"names":[],"mappings":";;
|
|
1
|
+
{"version":3,"file":"migrate-input-month.js","sourceRoot":"","sources":["../../../../../../../projects/cdk/schematics/ng-update/v5/steps/templates/migrate-input-month.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,15 +1,17 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.migrateInputPassword = migrateInputPassword;
|
|
4
|
+
const insert_todo_1 = require("../../../../utils/insert-todo");
|
|
4
5
|
const elements_1 = require("../../../../utils/templates/elements");
|
|
5
6
|
const template_resource_1 = require("../../../../utils/templates/template-resource");
|
|
7
|
+
const remove_attr_1 = require("../../../utils/templates/remove-attr");
|
|
6
8
|
const replace_tag_1 = require("../../../utils/templates/replace-tag");
|
|
7
9
|
function migrateInputPassword({ resource, recorder, fileSystem, }) {
|
|
8
10
|
const template = (0, template_resource_1.getTemplateFromTemplateResource)(resource, fileSystem);
|
|
9
11
|
const templateOffset = (0, template_resource_1.getTemplateOffset)(resource);
|
|
10
12
|
const elements = (0, elements_1.findElementsByTagName)(template, 'tui-input-password');
|
|
11
13
|
elements.forEach((element) => {
|
|
12
|
-
var _a, _b, _c, _d, _e, _f, _g, _h, _j;
|
|
14
|
+
var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k;
|
|
13
15
|
const sourceCodeLocation = element.sourceCodeLocation;
|
|
14
16
|
(0, replace_tag_1.replaceTag)(recorder, sourceCodeLocation, 'tui-input-password', 'tui-textfield', template, templateOffset);
|
|
15
17
|
const attrs = [...element.attrs].filter((attr) => /formcontrol|ngmodel/.exec(attr.name.toLocaleLowerCase()));
|
|
@@ -17,15 +19,42 @@ function migrateInputPassword({ resource, recorder, fileSystem, }) {
|
|
|
17
19
|
const { startOffset = 0, endOffset = 0 } = (_c = (_b = (_a = element.sourceCodeLocation) === null || _a === void 0 ? void 0 : _a.attrs) === null || _b === void 0 ? void 0 : _b[attr.name]) !== null && _c !== void 0 ? _c : {};
|
|
18
20
|
recorder.remove(templateOffset + startOffset, endOffset - startOffset);
|
|
19
21
|
}
|
|
22
|
+
const { value: labelOutsideValue, isBinding: labelOutsideIsBinding } = (0, remove_attr_1.removeAttr)(element, 'tuiTextfieldLabelOutside', recorder, templateOffset);
|
|
23
|
+
const isLabelOutsideTrue = labelOutsideValue === 'true' ||
|
|
24
|
+
(!labelOutsideIsBinding && labelOutsideValue === '');
|
|
25
|
+
const isDynamic = labelOutsideValue !== null &&
|
|
26
|
+
labelOutsideValue !== 'true' &&
|
|
27
|
+
labelOutsideValue !== 'false' &&
|
|
28
|
+
labelOutsideValue !== '';
|
|
29
|
+
// --- Handle label text ---
|
|
20
30
|
const labelIndex = element.childNodes.findIndex((node) => node.nodeName === '#text' && (node === null || node === void 0 ? void 0 : node.value.trim()));
|
|
31
|
+
let placeholderAttr = '';
|
|
21
32
|
if (labelIndex !== -1) {
|
|
22
33
|
const labelNode = element.childNodes[labelIndex];
|
|
34
|
+
const labelText = labelNode.value.trim();
|
|
23
35
|
const labelTextStart = ((_e = (_d = labelNode === null || labelNode === void 0 ? void 0 : labelNode.sourceCodeLocation) === null || _d === void 0 ? void 0 : _d.startOffset) !== null && _e !== void 0 ? _e : 0) + templateOffset;
|
|
24
36
|
const labelTextEnd = ((_g = (_f = labelNode === null || labelNode === void 0 ? void 0 : labelNode.sourceCodeLocation) === null || _f === void 0 ? void 0 : _f.endOffset) !== null && _g !== void 0 ? _g : 0) + templateOffset;
|
|
25
|
-
|
|
26
|
-
|
|
37
|
+
if (isLabelOutsideTrue) {
|
|
38
|
+
recorder.remove(labelTextStart, labelTextEnd - labelTextStart);
|
|
39
|
+
placeholderAttr = ` placeholder="${labelText}"`;
|
|
40
|
+
}
|
|
41
|
+
else if (!isDynamic) {
|
|
42
|
+
recorder.insertRight(labelTextStart, '\n<label tuiLabel>');
|
|
43
|
+
recorder.insertRight(labelTextEnd, '</label>\n');
|
|
44
|
+
}
|
|
27
45
|
}
|
|
28
|
-
|
|
46
|
+
// --- Build TODO comment ---
|
|
47
|
+
const todoNotes = [];
|
|
48
|
+
if (isDynamic) {
|
|
49
|
+
todoNotes.push(`[tuiTextfieldLabelOutside]="${labelOutsideValue}" is dynamic and cannot be migrated automatically. Use <label tuiLabel> inside <tui-textfield> for floating label or outside for static label.`);
|
|
50
|
+
}
|
|
51
|
+
if (todoNotes.length > 0) {
|
|
52
|
+
const startOffset = ((_h = sourceCodeLocation === null || sourceCodeLocation === void 0 ? void 0 : sourceCodeLocation.startOffset) !== null && _h !== void 0 ? _h : 0) + templateOffset;
|
|
53
|
+
const todoComment = `<!-- ${insert_todo_1.TODO_MARK} tui-input-password migration:\n${todoNotes.map((n) => ` - ${n}`).join('\n')}\n-->\n`;
|
|
54
|
+
recorder.insertLeft(startOffset, todoComment);
|
|
55
|
+
}
|
|
56
|
+
// --- Insert <input> and <tui-icon tuiPassword /> ---
|
|
57
|
+
const insertOffset = ((_k = (_j = sourceCodeLocation === null || sourceCodeLocation === void 0 ? void 0 : sourceCodeLocation.endTag) === null || _j === void 0 ? void 0 : _j.startOffset) !== null && _k !== void 0 ? _k : 0) + templateOffset;
|
|
29
58
|
const inputs = element.childNodes.filter((node) => node.nodeName === 'input');
|
|
30
59
|
const migrationAttrs = attrs.reduce((result, attr) => {
|
|
31
60
|
const name = attr.name
|
|
@@ -35,7 +64,7 @@ function migrateInputPassword({ resource, recorder, fileSystem, }) {
|
|
|
35
64
|
return `${result} ${name}="${attr.value}"`;
|
|
36
65
|
}, '');
|
|
37
66
|
if (!inputs.length) {
|
|
38
|
-
recorder.insertRight(insertOffset, `\n<input tuiInput type="password"${migrationAttrs} />\n<tui-icon tuiPassword />\n`);
|
|
67
|
+
recorder.insertRight(insertOffset, `\n<input tuiInput type="password"${migrationAttrs}${placeholderAttr} />\n<tui-icon tuiPassword />\n`);
|
|
39
68
|
}
|
|
40
69
|
for (const input of inputs) {
|
|
41
70
|
input.attrs.forEach((attr) => {
|
|
@@ -43,7 +72,7 @@ function migrateInputPassword({ resource, recorder, fileSystem, }) {
|
|
|
43
72
|
if (/^tuiTextfield$|^tuiTextfieldLegacy$/i.exec(attr.name)) {
|
|
44
73
|
const { startOffset = 0, endOffset = 0 } = (_c = (_b = (_a = input.sourceCodeLocation) === null || _a === void 0 ? void 0 : _a.attrs) === null || _b === void 0 ? void 0 : _b[attr.name]) !== null && _c !== void 0 ? _c : {};
|
|
45
74
|
recorder.remove(templateOffset + startOffset, endOffset - startOffset);
|
|
46
|
-
recorder.insertRight(templateOffset + startOffset, `tuiInput type="password"${migrationAttrs}`);
|
|
75
|
+
recorder.insertRight(templateOffset + startOffset, `tuiInput type="password"${migrationAttrs}${placeholderAttr}`);
|
|
47
76
|
const inputEndOffset = ((_e = (_d = input.sourceCodeLocation) === null || _d === void 0 ? void 0 : _d.endOffset) !== null && _e !== void 0 ? _e : 0) + templateOffset;
|
|
48
77
|
recorder.insertRight(inputEndOffset, '\n<tui-icon tuiPassword />\n');
|
|
49
78
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"migrate-input-password.js","sourceRoot":"","sources":["../../../../../../../projects/cdk/schematics/ng-update/v5/steps/templates/migrate-input-password.ts"],"names":[],"mappings":";;
|
|
1
|
+
{"version":3,"file":"migrate-input-password.js","sourceRoot":"","sources":["../../../../../../../projects/cdk/schematics/ng-update/v5/steps/templates/migrate-input-password.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,8 +1,10 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.migrateInputPhoneInternational = migrateInputPhoneInternational;
|
|
4
|
+
const insert_todo_1 = require("../../../../utils/insert-todo");
|
|
4
5
|
const elements_1 = require("../../../../utils/templates/elements");
|
|
5
6
|
const template_resource_1 = require("../../../../utils/templates/template-resource");
|
|
7
|
+
const remove_attr_1 = require("../../../utils/templates/remove-attr");
|
|
6
8
|
const replace_tag_1 = require("../../../utils/templates/replace-tag");
|
|
7
9
|
const INPUT_ATTRS = new Set([
|
|
8
10
|
'(countryIsoCodeChange)'.toLowerCase(),
|
|
@@ -17,31 +19,46 @@ function migrateInputPhoneInternational({ resource, recorder, fileSystem, }) {
|
|
|
17
19
|
const templateOffset = (0, template_resource_1.getTemplateOffset)(resource);
|
|
18
20
|
const elements = (0, elements_1.findElementsByTagName)(template, 'tui-input-phone-international');
|
|
19
21
|
elements.forEach((element) => {
|
|
20
|
-
var _a, _b, _c, _d, _e, _f, _g, _h, _j;
|
|
22
|
+
var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k;
|
|
21
23
|
const sourceCodeLocation = element.sourceCodeLocation;
|
|
22
24
|
(0, replace_tag_1.replaceTag)(recorder, sourceCodeLocation, 'tui-input-phone-international', 'tui-textfield', template, templateOffset);
|
|
23
25
|
const controlAttrs = [...element.attrs].filter((attr) => /formcontrol|ngmodel/.exec(attr.name.toLocaleLowerCase()));
|
|
24
26
|
const inputAttrs = [...element.attrs].filter((attr) => INPUT_ATTRS.has(attr.name.toLowerCase()));
|
|
27
|
+
const { value: labelOutside, isBinding: labelOutsideIsBinding } = (0, remove_attr_1.removeAttr)(element, 'tuiTextfieldLabelOutside', recorder, templateOffset);
|
|
28
|
+
const isLabelOutsideTrue = labelOutside === 'true' || (!labelOutsideIsBinding && labelOutside === '');
|
|
29
|
+
const isDynamic = labelOutside !== null && !isLabelOutsideTrue && labelOutside !== 'false';
|
|
25
30
|
for (const attr of [...controlAttrs, ...inputAttrs]) {
|
|
26
31
|
const { startOffset = 0, endOffset = 0 } = (_c = (_b = (_a = element.sourceCodeLocation) === null || _a === void 0 ? void 0 : _a.attrs) === null || _b === void 0 ? void 0 : _b[attr.name]) !== null && _c !== void 0 ? _c : {};
|
|
27
32
|
recorder.remove(templateOffset + startOffset, endOffset - startOffset);
|
|
28
33
|
}
|
|
29
34
|
const labelIndex = element.childNodes.findIndex((node) => node.nodeName === '#text' && (node === null || node === void 0 ? void 0 : node.value.trim()));
|
|
35
|
+
let placeholderAttr = '';
|
|
30
36
|
if (labelIndex !== -1) {
|
|
31
37
|
const labelNode = element.childNodes[labelIndex];
|
|
38
|
+
const labelText = labelNode.value.trim();
|
|
32
39
|
const labelTextStart = ((_e = (_d = labelNode === null || labelNode === void 0 ? void 0 : labelNode.sourceCodeLocation) === null || _d === void 0 ? void 0 : _d.startOffset) !== null && _e !== void 0 ? _e : 0) + templateOffset;
|
|
33
40
|
const labelTextEnd = ((_g = (_f = labelNode === null || labelNode === void 0 ? void 0 : labelNode.sourceCodeLocation) === null || _f === void 0 ? void 0 : _f.endOffset) !== null && _g !== void 0 ? _g : 0) + templateOffset;
|
|
34
|
-
|
|
35
|
-
|
|
41
|
+
if (isLabelOutsideTrue) {
|
|
42
|
+
recorder.remove(labelTextStart, labelTextEnd - labelTextStart);
|
|
43
|
+
placeholderAttr = ` placeholder="${labelText}"`;
|
|
44
|
+
}
|
|
45
|
+
else if (!isDynamic) {
|
|
46
|
+
recorder.insertRight(labelTextStart, '\n<label tuiLabel>');
|
|
47
|
+
recorder.insertRight(labelTextEnd, '</label>\n');
|
|
48
|
+
}
|
|
36
49
|
}
|
|
37
|
-
|
|
50
|
+
if (isDynamic) {
|
|
51
|
+
const insertAt = ((_h = sourceCodeLocation === null || sourceCodeLocation === void 0 ? void 0 : sourceCodeLocation.startOffset) !== null && _h !== void 0 ? _h : 0) + templateOffset;
|
|
52
|
+
recorder.insertLeft(insertAt, `<!-- ${insert_todo_1.TODO_MARK} [tuiTextfieldLabelOutside] is dynamic — cannot be migrated automatically. Use <label tuiLabel> inside <tui-textfield> for label-outside pattern.\n-->\n`);
|
|
53
|
+
}
|
|
54
|
+
const insertOffset = ((_k = (_j = sourceCodeLocation === null || sourceCodeLocation === void 0 ? void 0 : sourceCodeLocation.endTag) === null || _j === void 0 ? void 0 : _j.startOffset) !== null && _k !== void 0 ? _k : 0) + templateOffset;
|
|
38
55
|
const inputs = element.childNodes.filter((node) => node.nodeName === 'input');
|
|
39
56
|
const migrationAttrs = [...controlAttrs, ...inputAttrs].reduce((result, attr) => {
|
|
40
57
|
const name = normalizeAttrName(attr.name);
|
|
41
58
|
return attr.value ? `${result} ${name}="${attr.value}"` : `${result} ${name}`;
|
|
42
59
|
}, '');
|
|
43
60
|
if (!inputs.length) {
|
|
44
|
-
recorder.insertRight(insertOffset, `\n<input tuiInputPhoneInternational${migrationAttrs} />\n`);
|
|
61
|
+
recorder.insertRight(insertOffset, `\n<input tuiInputPhoneInternational${migrationAttrs}${placeholderAttr} />\n`);
|
|
45
62
|
}
|
|
46
63
|
for (const input of inputs) {
|
|
47
64
|
input.attrs.forEach((attr) => {
|
|
@@ -49,7 +66,7 @@ function migrateInputPhoneInternational({ resource, recorder, fileSystem, }) {
|
|
|
49
66
|
if (/^tuiTextfield$|^tuiTextfieldLegacy$/i.exec(attr.name)) {
|
|
50
67
|
const { startOffset = 0, endOffset = 0 } = (_c = (_b = (_a = input.sourceCodeLocation) === null || _a === void 0 ? void 0 : _a.attrs) === null || _b === void 0 ? void 0 : _b[attr.name]) !== null && _c !== void 0 ? _c : {};
|
|
51
68
|
recorder.remove(templateOffset + startOffset, endOffset - startOffset);
|
|
52
|
-
recorder.insertRight(templateOffset + startOffset, `tuiInputPhoneInternational${migrationAttrs}`);
|
|
69
|
+
recorder.insertRight(templateOffset + startOffset, `tuiInputPhoneInternational${migrationAttrs}${placeholderAttr}`);
|
|
53
70
|
}
|
|
54
71
|
});
|
|
55
72
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"migrate-input-phone-international.js","sourceRoot":"","sources":["../../../../../../../projects/cdk/schematics/ng-update/v5/steps/templates/migrate-input-phone-international.ts"],"names":[],"mappings":";;
|
|
1
|
+
{"version":3,"file":"migrate-input-phone-international.js","sourceRoot":"","sources":["../../../../../../../projects/cdk/schematics/ng-update/v5/steps/templates/migrate-input-phone-international.ts"],"names":[],"mappings":"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"}
|
|
@@ -4,6 +4,7 @@ exports.migrateInputPhone = migrateInputPhone;
|
|
|
4
4
|
const insert_todo_1 = require("../../../../utils/insert-todo");
|
|
5
5
|
const elements_1 = require("../../../../utils/templates/elements");
|
|
6
6
|
const template_resource_1 = require("../../../../utils/templates/template-resource");
|
|
7
|
+
const remove_attr_1 = require("../../../utils/templates/remove-attr");
|
|
7
8
|
const replace_tag_1 = require("../../../utils/templates/replace-tag");
|
|
8
9
|
const DOCS_LINK = 'https://taiga-ui.dev/components/input-phone';
|
|
9
10
|
const INPUT_ATTRS = new Set(['[allowText]'.toLowerCase(), 'allowText'.toLowerCase()]);
|
|
@@ -16,9 +17,12 @@ function migrateInputPhone({ resource, recorder, fileSystem, }) {
|
|
|
16
17
|
const templateOffset = (0, template_resource_1.getTemplateOffset)(resource);
|
|
17
18
|
const elements = (0, elements_1.findElementsByTagName)(template, 'tui-input-phone');
|
|
18
19
|
elements.forEach((element) => {
|
|
19
|
-
var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k;
|
|
20
|
+
var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l;
|
|
20
21
|
const sourceCodeLocation = element.sourceCodeLocation;
|
|
21
22
|
(0, replace_tag_1.replaceTag)(recorder, sourceCodeLocation, 'tui-input-phone', 'tui-textfield', template, templateOffset);
|
|
23
|
+
const { value: labelOutside, isBinding: labelOutsideIsBinding } = (0, remove_attr_1.removeAttr)(element, 'tuiTextfieldLabelOutside', recorder, templateOffset);
|
|
24
|
+
const isLabelOutsideTrue = labelOutside === 'true' || (!labelOutsideIsBinding && labelOutside === '');
|
|
25
|
+
const isDynamic = labelOutside !== null && !isLabelOutsideTrue && labelOutside !== 'false';
|
|
22
26
|
const controlAttrs = [...element.attrs].filter((attr) => /formcontrol|ngmodel/.exec(attr.name.toLocaleLowerCase()));
|
|
23
27
|
const inputAttrs = [...element.attrs].filter((attr) => INPUT_ATTRS.has(attr.name.toLowerCase()));
|
|
24
28
|
const noEquivalentAttrs = [...element.attrs].filter((attr) => NO_EQUIVALENT_ATTRS.has(attr.name.toLowerCase()));
|
|
@@ -27,14 +31,26 @@ function migrateInputPhone({ resource, recorder, fileSystem, }) {
|
|
|
27
31
|
recorder.remove(templateOffset + startOffset, endOffset - startOffset);
|
|
28
32
|
}
|
|
29
33
|
const labelIndex = element.childNodes.findIndex((node) => node.nodeName === '#text' && (node === null || node === void 0 ? void 0 : node.value.trim()));
|
|
34
|
+
let placeholderAttr = '';
|
|
30
35
|
if (labelIndex !== -1) {
|
|
31
36
|
const labelNode = element.childNodes[labelIndex];
|
|
37
|
+
const labelText = labelNode.value.trim();
|
|
32
38
|
const labelTextStart = ((_e = (_d = labelNode === null || labelNode === void 0 ? void 0 : labelNode.sourceCodeLocation) === null || _d === void 0 ? void 0 : _d.startOffset) !== null && _e !== void 0 ? _e : 0) + templateOffset;
|
|
33
39
|
const labelTextEnd = ((_g = (_f = labelNode === null || labelNode === void 0 ? void 0 : labelNode.sourceCodeLocation) === null || _f === void 0 ? void 0 : _f.endOffset) !== null && _g !== void 0 ? _g : 0) + templateOffset;
|
|
34
|
-
|
|
35
|
-
|
|
40
|
+
if (isLabelOutsideTrue) {
|
|
41
|
+
recorder.remove(labelTextStart, labelTextEnd - labelTextStart);
|
|
42
|
+
placeholderAttr = ` placeholder="${labelText}"`;
|
|
43
|
+
}
|
|
44
|
+
else if (!isDynamic) {
|
|
45
|
+
recorder.insertRight(labelTextStart, '\n<label tuiLabel>');
|
|
46
|
+
recorder.insertRight(labelTextEnd, '</label>\n');
|
|
47
|
+
}
|
|
36
48
|
}
|
|
37
|
-
|
|
49
|
+
if (isDynamic) {
|
|
50
|
+
const insertAt = ((_h = sourceCodeLocation === null || sourceCodeLocation === void 0 ? void 0 : sourceCodeLocation.startOffset) !== null && _h !== void 0 ? _h : 0) + templateOffset;
|
|
51
|
+
recorder.insertLeft(insertAt, `<!-- ${insert_todo_1.TODO_MARK} [tuiTextfieldLabelOutside] is dynamic — cannot be migrated automatically. Use <label tuiLabel> inside <tui-textfield> for label-outside pattern.\n-->\n`);
|
|
52
|
+
}
|
|
53
|
+
const inputInsertOffset = ((_k = (_j = sourceCodeLocation === null || sourceCodeLocation === void 0 ? void 0 : sourceCodeLocation.endTag) === null || _j === void 0 ? void 0 : _j.startOffset) !== null && _k !== void 0 ? _k : 0) + templateOffset;
|
|
38
54
|
const inputs = element.childNodes.filter((node) => node.nodeName === 'input');
|
|
39
55
|
const migrationAttrs = [...controlAttrs, ...inputAttrs].reduce((result, attr) => {
|
|
40
56
|
const name = normalizeAttrName(attr.name);
|
|
@@ -49,17 +65,19 @@ function migrateInputPhone({ resource, recorder, fileSystem, }) {
|
|
|
49
65
|
' Replace with: <input tuiInputPhone [mask]="phoneOptions" /> where',
|
|
50
66
|
" phoneOptions = maskitoPhoneOptionsGenerator({countryIsoCode: 'RU', metadata}) from @maskito/phone. -->",
|
|
51
67
|
].join('\n');
|
|
52
|
-
const insertAt = ((
|
|
68
|
+
const insertAt = ((_l = sourceCodeLocation === null || sourceCodeLocation === void 0 ? void 0 : sourceCodeLocation.startOffset) !== null && _l !== void 0 ? _l : 0) + templateOffset;
|
|
53
69
|
recorder.insertLeft(insertAt, `${todoComment}\n`);
|
|
54
70
|
}
|
|
55
|
-
recorder.insertRight(inputInsertOffset, inputs.length
|
|
71
|
+
recorder.insertRight(inputInsertOffset, inputs.length
|
|
72
|
+
? ''
|
|
73
|
+
: `\n<input tuiInputPhone${migrationAttrs}${placeholderAttr} />\n`);
|
|
56
74
|
for (const input of inputs) {
|
|
57
75
|
input.attrs.forEach((attr) => {
|
|
58
76
|
var _a, _b, _c;
|
|
59
77
|
if (/^tuiTextfield$|^tuiTextfieldLegacy$/i.exec(attr.name)) {
|
|
60
78
|
const { startOffset = 0, endOffset = 0 } = (_c = (_b = (_a = input.sourceCodeLocation) === null || _a === void 0 ? void 0 : _a.attrs) === null || _b === void 0 ? void 0 : _b[attr.name]) !== null && _c !== void 0 ? _c : {};
|
|
61
79
|
recorder.remove(templateOffset + startOffset, endOffset - startOffset);
|
|
62
|
-
recorder.insertRight(templateOffset + startOffset, `tuiInputPhone${migrationAttrs}`);
|
|
80
|
+
recorder.insertRight(templateOffset + startOffset, `tuiInputPhone${migrationAttrs}${placeholderAttr}`);
|
|
63
81
|
}
|
|
64
82
|
});
|
|
65
83
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"migrate-input-phone.js","sourceRoot":"","sources":["../../../../../../../projects/cdk/schematics/ng-update/v5/steps/templates/migrate-input-phone.ts"],"names":[],"mappings":";;
|
|
1
|
+
{"version":3,"file":"migrate-input-phone.js","sourceRoot":"","sources":["../../../../../../../projects/cdk/schematics/ng-update/v5/steps/templates/migrate-input-phone.ts"],"names":[],"mappings":"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"}
|
|
@@ -4,6 +4,7 @@ exports.migrateInputTag = migrateInputTag;
|
|
|
4
4
|
const insert_todo_1 = require("../../../../utils/insert-todo");
|
|
5
5
|
const elements_1 = require("../../../../utils/templates/elements");
|
|
6
6
|
const template_resource_1 = require("../../../../utils/templates/template-resource");
|
|
7
|
+
const remove_attr_1 = require("../../../utils/templates/remove-attr");
|
|
7
8
|
const replace_tag_1 = require("../../../utils/templates/replace-tag");
|
|
8
9
|
const DOCS_LINK = 'https://taiga-ui.dev/components/input-chip';
|
|
9
10
|
const INPUT_ATTR_RENAMES = new Map([
|
|
@@ -43,9 +44,12 @@ function migrateInputTag({ resource, recorder, fileSystem, }) {
|
|
|
43
44
|
const templateOffset = (0, template_resource_1.getTemplateOffset)(resource);
|
|
44
45
|
const elements = (0, elements_1.findElementsByTagName)(template, 'tui-input-tag');
|
|
45
46
|
elements.forEach((element) => {
|
|
46
|
-
var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m;
|
|
47
|
+
var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o;
|
|
47
48
|
const sourceCodeLocation = element.sourceCodeLocation;
|
|
48
49
|
(0, replace_tag_1.replaceTag)(recorder, sourceCodeLocation, 'tui-input-tag', 'tui-textfield', template, templateOffset);
|
|
50
|
+
const { value: labelOutside, isBinding: labelOutsideIsBinding } = (0, remove_attr_1.removeAttr)(element, 'tuiTextfieldLabelOutside', recorder, templateOffset);
|
|
51
|
+
const isLabelOutsideTrue = labelOutside === 'true' || (!labelOutsideIsBinding && labelOutside === '');
|
|
52
|
+
const isDynamic = labelOutside !== null && !isLabelOutsideTrue && labelOutside !== 'false';
|
|
49
53
|
const openTagEnd = (_b = (_a = sourceCodeLocation === null || sourceCodeLocation === void 0 ? void 0 : sourceCodeLocation.startTag) === null || _a === void 0 ? void 0 : _a.endOffset) !== null && _b !== void 0 ? _b : 0;
|
|
50
54
|
const controlAttrs = [...element.attrs].filter((attr) => /formcontrol|ngmodel/.exec(attr.name.toLocaleLowerCase()));
|
|
51
55
|
const inputAttrs = [...element.attrs].filter((attr) => INPUT_ATTR_RENAMES.has(attr.name.toLowerCase()));
|
|
@@ -69,12 +73,24 @@ function migrateInputTag({ resource, recorder, fileSystem, }) {
|
|
|
69
73
|
}, '');
|
|
70
74
|
recorder.insertRight(templateOffset + openTagEnd - 1, ` multi${textfieldAttrStr}`);
|
|
71
75
|
const labelIndex = element.childNodes.findIndex((node) => node.nodeName === '#text' && (node === null || node === void 0 ? void 0 : node.value.trim()));
|
|
76
|
+
let placeholderAttr = '';
|
|
72
77
|
if (labelIndex !== -1) {
|
|
73
78
|
const labelNode = element.childNodes[labelIndex];
|
|
79
|
+
const labelText = labelNode.value.trim();
|
|
74
80
|
const labelTextStart = ((_g = (_f = labelNode === null || labelNode === void 0 ? void 0 : labelNode.sourceCodeLocation) === null || _f === void 0 ? void 0 : _f.startOffset) !== null && _g !== void 0 ? _g : 0) + templateOffset;
|
|
75
81
|
const labelTextEnd = ((_j = (_h = labelNode === null || labelNode === void 0 ? void 0 : labelNode.sourceCodeLocation) === null || _h === void 0 ? void 0 : _h.endOffset) !== null && _j !== void 0 ? _j : 0) + templateOffset;
|
|
76
|
-
|
|
77
|
-
|
|
82
|
+
if (isLabelOutsideTrue) {
|
|
83
|
+
recorder.remove(labelTextStart, labelTextEnd - labelTextStart);
|
|
84
|
+
placeholderAttr = ` placeholder="${labelText}"`;
|
|
85
|
+
}
|
|
86
|
+
else if (!isDynamic) {
|
|
87
|
+
recorder.insertRight(labelTextStart, '\n<label tuiLabel>');
|
|
88
|
+
recorder.insertRight(labelTextEnd, '</label>\n');
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
if (isDynamic) {
|
|
92
|
+
const insertAt = ((_k = sourceCodeLocation === null || sourceCodeLocation === void 0 ? void 0 : sourceCodeLocation.startOffset) !== null && _k !== void 0 ? _k : 0) + templateOffset;
|
|
93
|
+
recorder.insertLeft(insertAt, `<!-- ${insert_todo_1.TODO_MARK} [tuiTextfieldLabelOutside] is dynamic — cannot be migrated automatically. Use <label tuiLabel> inside <tui-textfield> for label-outside pattern.\n-->\n`);
|
|
78
94
|
}
|
|
79
95
|
if (todoAttrs.length > 0) {
|
|
80
96
|
const lines = todoAttrs.map((attr, index, arr) => {
|
|
@@ -86,15 +102,15 @@ function migrateInputTag({ resource, recorder, fileSystem, }) {
|
|
|
86
102
|
`<!-- ${insert_todo_1.TODO_MARK} tui-input-tag migration (see ${DOCS_LINK}):`,
|
|
87
103
|
...lines,
|
|
88
104
|
].join('\n');
|
|
89
|
-
const insertAt = ((
|
|
105
|
+
const insertAt = ((_l = sourceCodeLocation === null || sourceCodeLocation === void 0 ? void 0 : sourceCodeLocation.startOffset) !== null && _l !== void 0 ? _l : 0) + templateOffset;
|
|
90
106
|
recorder.insertLeft(insertAt, `${todoComment}\n`);
|
|
91
107
|
}
|
|
92
|
-
const insertOffset = ((
|
|
108
|
+
const insertOffset = ((_o = (_m = sourceCodeLocation === null || sourceCodeLocation === void 0 ? void 0 : sourceCodeLocation.endTag) === null || _m === void 0 ? void 0 : _m.startOffset) !== null && _o !== void 0 ? _o : 0) + templateOffset;
|
|
93
109
|
const migrationAttrs = [...controlAttrs, ...inputAttrs].reduce((result, attr) => {
|
|
94
110
|
const name = normalizeAttrName(attr.name);
|
|
95
111
|
return attr.value ? `${result} ${name}="${attr.value}"` : `${result} ${name}`;
|
|
96
112
|
}, '');
|
|
97
|
-
recorder.insertRight(insertOffset, `\n<input tuiInputChip${migrationAttrs} />\n`);
|
|
113
|
+
recorder.insertRight(insertOffset, `\n<input tuiInputChip${migrationAttrs}${placeholderAttr} />\n`);
|
|
98
114
|
});
|
|
99
115
|
}
|
|
100
116
|
function getHint(attrName) {
|