@rdlabo/ionic-theme-ios26 0.0.3 → 0.1.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.
Files changed (165) hide show
  1. package/.github/workflows/lint.yml +40 -0
  2. package/FEEDBACK.md +100 -7
  3. package/FEEDBACK2.md +45 -0
  4. package/README.md +101 -40
  5. package/USING_ION_ITEM_GROUP.md +7 -9
  6. package/demo/eslint.config.js +2 -0
  7. package/demo/src/app/album/album-page.component.html +3 -3
  8. package/demo/src/app/album/album-page.component.scss +0 -14
  9. package/demo/src/app/album/album-page.component.spec.ts +1 -1
  10. package/demo/src/app/health/health-page.component.html +3 -3
  11. package/demo/src/app/health/health-page.component.spec.ts +2 -2
  12. package/demo/src/app/index/index-page.component.html +17 -7
  13. package/demo/src/app/index/index-page.component.spec.ts +6 -6
  14. package/demo/src/app/index/index-page.component.ts +29 -35
  15. package/demo/src/app/index/index.routes.ts +84 -0
  16. package/demo/src/app/index/pages/accordion/accordion.page.html +45 -0
  17. package/demo/src/app/index/pages/accordion/accordion.page.scss +0 -0
  18. package/demo/src/app/index/pages/accordion/accordion.page.spec.ts +21 -0
  19. package/demo/src/app/index/pages/accordion/accordion.page.ts +47 -0
  20. package/demo/src/app/index/pages/action-sheet/action-sheet.page.spec.ts +5 -1
  21. package/demo/src/app/index/pages/action-sheet/action-sheet.page.ts +3 -5
  22. package/demo/src/app/index/pages/alert/alert.page.spec.ts +5 -1
  23. package/demo/src/app/index/pages/alert/alert.page.ts +0 -2
  24. package/demo/src/app/index/pages/breadcrumbs/breadcrumbs.page.html +41 -0
  25. package/demo/src/app/index/pages/breadcrumbs/breadcrumbs.page.scss +0 -0
  26. package/demo/src/app/index/pages/breadcrumbs/breadcrumbs.page.spec.ts +21 -0
  27. package/demo/src/app/index/pages/breadcrumbs/breadcrumbs.page.ts +47 -0
  28. package/demo/src/app/index/pages/button/button.page.html +41 -19
  29. package/demo/src/app/index/pages/button/button.page.scss +3 -0
  30. package/demo/src/app/index/pages/button/button.page.spec.ts +5 -1
  31. package/demo/src/app/index/pages/button/button.page.ts +0 -2
  32. package/demo/src/app/index/pages/card/card.page.html +171 -0
  33. package/demo/src/app/index/pages/card/card.page.scss +0 -0
  34. package/demo/src/app/index/pages/card/card.page.spec.ts +21 -0
  35. package/demo/src/app/index/pages/card/card.page.ts +57 -0
  36. package/demo/src/app/index/pages/checkbox/checkbox.page.spec.ts +5 -1
  37. package/demo/src/app/index/pages/checkbox/checkbox.page.ts +0 -2
  38. package/demo/src/app/index/pages/chip/chip.page.html +72 -0
  39. package/demo/src/app/index/pages/chip/chip.page.scss +0 -0
  40. package/demo/src/app/index/pages/chip/chip.page.spec.ts +21 -0
  41. package/demo/src/app/index/pages/chip/chip.page.ts +47 -0
  42. package/demo/src/app/index/pages/date-and-time-pickers/date-and-time-pickers.page.html +48 -0
  43. package/demo/src/app/index/pages/date-and-time-pickers/date-and-time-pickers.page.scss +0 -0
  44. package/demo/src/app/index/pages/date-and-time-pickers/date-and-time-pickers.page.spec.ts +21 -0
  45. package/demo/src/app/index/pages/date-and-time-pickers/date-and-time-pickers.page.ts +55 -0
  46. package/demo/src/app/index/pages/floating-action-button/floating-action-button.page.html +106 -0
  47. package/demo/src/app/index/pages/floating-action-button/floating-action-button.page.scss +0 -0
  48. package/demo/src/app/index/pages/floating-action-button/floating-action-button.page.spec.ts +21 -0
  49. package/demo/src/app/index/pages/floating-action-button/floating-action-button.page.ts +49 -0
  50. package/demo/src/app/index/pages/inputs/inputs.page.html +65 -0
  51. package/demo/src/app/index/pages/inputs/inputs.page.scss +0 -0
  52. package/demo/src/app/index/pages/inputs/inputs.page.spec.ts +21 -0
  53. package/demo/src/app/index/pages/inputs/inputs.page.ts +49 -0
  54. package/demo/src/app/index/pages/item-list/item-list.page.html +52 -0
  55. package/demo/src/app/index/pages/item-list/item-list.page.scss +0 -0
  56. package/demo/src/app/index/pages/item-list/item-list.page.spec.ts +21 -0
  57. package/demo/src/app/index/pages/item-list/item-list.page.ts +47 -0
  58. package/demo/src/app/index/pages/menu/menu.page.html +13 -0
  59. package/demo/src/app/index/pages/menu/menu.page.scss +0 -0
  60. package/demo/src/app/index/pages/menu/menu.page.spec.ts +21 -0
  61. package/demo/src/app/index/pages/menu/menu.page.ts +17 -0
  62. package/demo/src/app/index/pages/modal/modal.page.html +37 -0
  63. package/demo/src/app/index/pages/modal/modal.page.scss +0 -0
  64. package/demo/src/app/index/pages/modal/modal.page.spec.ts +21 -0
  65. package/demo/src/app/index/pages/modal/modal.page.ts +77 -0
  66. package/demo/src/app/index/pages/popover/popover.page.html +34 -0
  67. package/demo/src/app/index/pages/popover/popover.page.scss +0 -0
  68. package/demo/src/app/index/pages/popover/popover.page.spec.ts +21 -0
  69. package/demo/src/app/index/pages/popover/popover.page.ts +47 -0
  70. package/demo/src/app/index/pages/progress-indicators/progress-indicators.page.html +28 -0
  71. package/demo/src/app/index/pages/progress-indicators/progress-indicators.page.scss +0 -0
  72. package/demo/src/app/index/pages/progress-indicators/progress-indicators.page.spec.ts +21 -0
  73. package/demo/src/app/index/pages/progress-indicators/progress-indicators.page.ts +47 -0
  74. package/demo/src/app/index/pages/radio/radio.page.html +39 -0
  75. package/demo/src/app/index/pages/radio/radio.page.scss +0 -0
  76. package/demo/src/app/index/pages/radio/radio.page.spec.ts +21 -0
  77. package/demo/src/app/index/pages/radio/radio.page.ts +47 -0
  78. package/demo/src/app/index/pages/range/range.page.html +58 -0
  79. package/demo/src/app/index/pages/range/range.page.scss +0 -0
  80. package/demo/src/app/index/pages/range/range.page.spec.ts +21 -0
  81. package/demo/src/app/index/pages/range/range.page.ts +49 -0
  82. package/demo/src/app/index/pages/reorder/reorder.page.html +52 -0
  83. package/demo/src/app/index/pages/reorder/reorder.page.scss +0 -0
  84. package/demo/src/app/index/pages/reorder/reorder.page.spec.ts +21 -0
  85. package/demo/src/app/index/pages/reorder/reorder.page.ts +47 -0
  86. package/demo/src/app/index/pages/searchbar/searchbar.page.html +33 -0
  87. package/demo/src/app/index/pages/searchbar/searchbar.page.scss +0 -0
  88. package/demo/src/app/index/pages/searchbar/searchbar.page.spec.ts +21 -0
  89. package/demo/src/app/index/pages/searchbar/searchbar.page.ts +45 -0
  90. package/demo/src/app/index/pages/segment/segment.page.html +107 -0
  91. package/demo/src/app/index/pages/segment/segment.page.scss +1 -0
  92. package/demo/src/app/index/pages/segment/segment.page.spec.ts +21 -0
  93. package/demo/src/app/index/pages/segment/segment.page.ts +51 -0
  94. package/demo/src/app/index/pages/select/select.page.html +74 -0
  95. package/demo/src/app/index/pages/select/select.page.scss +0 -0
  96. package/demo/src/app/index/pages/select/select.page.spec.ts +21 -0
  97. package/demo/src/app/index/pages/select/select.page.ts +50 -0
  98. package/demo/src/app/index/pages/tabs/tabs.page.html +78 -0
  99. package/demo/src/app/index/pages/tabs/tabs.page.scss +6 -0
  100. package/demo/src/app/index/pages/tabs/tabs.page.spec.ts +21 -0
  101. package/demo/src/app/index/pages/tabs/tabs.page.ts +47 -0
  102. package/demo/src/app/index/pages/toast/toast.page.html +32 -0
  103. package/demo/src/app/index/pages/toast/toast.page.scss +0 -0
  104. package/demo/src/app/index/pages/toast/toast.page.spec.ts +21 -0
  105. package/demo/src/app/index/pages/toast/toast.page.ts +66 -0
  106. package/demo/src/app/index/pages/toggle/toggle.page.html +45 -0
  107. package/demo/src/app/index/pages/toggle/toggle.page.scss +0 -0
  108. package/demo/src/app/index/pages/toggle/toggle.page.spec.ts +21 -0
  109. package/demo/src/app/index/pages/toggle/toggle.page.ts +49 -0
  110. package/demo/src/app/index/pages/toolbar/toolbar.page.html +121 -0
  111. package/demo/src/app/index/pages/toolbar/toolbar.page.scss +0 -0
  112. package/demo/src/app/index/pages/toolbar/toolbar.page.spec.ts +21 -0
  113. package/demo/src/app/index/pages/toolbar/toolbar.page.ts +55 -0
  114. package/demo/src/app/settings/settings-page.component.html +4 -7
  115. package/demo/src/app/settings/settings-page.component.spec.ts +2 -2
  116. package/demo/src/app/tabs/tabs.page.html +4 -4
  117. package/demo/src/app/tabs/tabs.page.spec.ts +1 -1
  118. package/demo/src/app/tabs/tabs.routes.ts +0 -1
  119. package/demo/src/global.scss +28 -10
  120. package/demo/src/index.html +1 -1
  121. package/demo/src/test.ts +7 -0
  122. package/demo/src/theme/variables.scss +18 -0
  123. package/demo/util/mocks/angular/angular-delegate.ts +18 -0
  124. package/demo/util/mocks/angular/ion-router-outlet.ts +39 -0
  125. package/demo/util/mocks/angular/modal-controller.ts +7 -0
  126. package/demo/util/mocks/angular/nav-controller.ts +22 -0
  127. package/demo/util/mocks/angular/popover-controller.ts +7 -0
  128. package/demo/util/mocks/util/base.mock.ts +13 -0
  129. package/demo/util/mocks/util/overlay.ts +13 -0
  130. package/demo/util/test.config.ts +54 -0
  131. package/package.json +3 -2
  132. package/src/components/ion-action-sheet.scss +27 -4
  133. package/src/components/ion-alert.scss +16 -2
  134. package/src/components/ion-breadcrumbs.scss +24 -0
  135. package/src/components/ion-button.scss +111 -62
  136. package/src/components/ion-card.scss +5 -1
  137. package/src/components/ion-chip.scss +10 -0
  138. package/src/components/ion-content.scss +13 -0
  139. package/src/components/ion-datetime.scss +9 -0
  140. package/src/components/ion-fab.scss +10 -4
  141. package/src/components/ion-list.scss +9 -2
  142. package/src/components/ion-loading.scss +9 -0
  143. package/src/components/ion-modal.scss +26 -1
  144. package/src/components/ion-picker.scss +4 -0
  145. package/src/components/ion-popover.scss +8 -16
  146. package/src/components/ion-range.scss +21 -0
  147. package/src/components/ion-searchbar.scss +2 -2
  148. package/src/components/ion-segment.scss +40 -5
  149. package/src/components/ion-tabs.scss +23 -8
  150. package/src/components/ion-toast.scss +11 -2
  151. package/src/components/ion-toggle.scss +37 -28
  152. package/src/components/ion-toolbar.scss +27 -0
  153. package/src/{utils/default-variables.scss → default-variables.scss} +5 -1
  154. package/src/ionic-theme-ios26-dark-always.scss +6 -0
  155. package/src/{ionic-theme-dark-class.scss → ionic-theme-ios26-dark-class.scss} +1 -1
  156. package/src/{ionic-theme-dark-system.scss → ionic-theme-ios26-dark-system.scss} +1 -1
  157. package/src/ionic-theme-ios26.scss +8 -18
  158. package/src/utils/api.scss +9 -8
  159. package/src/utils/dark/ion-button.scss +45 -0
  160. package/src/{components-dark → utils}/theme-dark.scss +5 -3
  161. package/src/utils/theme-list-inset.scss +24 -19
  162. package/src/utils/translucent.scss +59 -58
  163. package/build-sass.js +0 -25
  164. package/demo/src/theme/theme-ios26.scss +0 -25
  165. package/src/components-dark/ion-button.scss +0 -28
@@ -0,0 +1,24 @@
1
+ /**
2
+ * Since there is no official Apple version,
3
+ * and this style is not stylish as iOS 26. it will be removed.
4
+ */
5
+
6
+ //@use '../utils/api';
7
+ //
8
+ //ion-breadcrumbs.ios:not(.ios26-disabled) {
9
+ // ion-breadcrumb {
10
+ // &::part(native) {
11
+ // transition: transform 100ms ease-out;
12
+ // @include api.glass-background;
13
+ // border-radius: 24px;
14
+ // margin-inline: 12px;
15
+ //
16
+ // padding-inline: 12px;
17
+ // padding-top: 6px;
18
+ // padding-bottom: 6px;
19
+ // }
20
+ // &.ion-activated::part(native) {
21
+ // transform: scale(1.18);
22
+ // }
23
+ // }
24
+ //}
@@ -1,111 +1,160 @@
1
1
  @use '../utils/api';
2
2
 
3
- @mixin theme-button {
4
- max-height: inherit;
5
- margin: 8px 4px;
6
- &:first-child {
7
- margin-left: 12px;
3
+ /**
4
+ * Note: ion-back-button should not put inner ion-button.
5
+ * feat(): ion-config new property for disable ion-back-button Animation
6
+ */
7
+
8
+ @mixin theme-buttons {
9
+ @include api.glass-background;
10
+ border-radius: 25px;
11
+ overflow: hidden;
12
+ transition: transform 100ms ease-out !important;
13
+
14
+ &:has(.ion-activated) {
15
+ transform: scale(1.28);
16
+ }
17
+
18
+ ion-button:not(.ios26-disabled),
19
+ ion-back-button:not(.ios26-disabled) {
20
+ transform: none;
21
+
22
+ &:not(.button-disabled) {
23
+ opacity: 1;
24
+ }
25
+
26
+ &.ion-activated {
27
+ --color: rgba(var(--ion-text-color-rgb, 0, 0, 0), 0.1);
28
+ &.ion-color {
29
+ --color: rgba(var(--ion-color-base-rgb, var(--ion-text-color-rgb, 0, 0, 0)), 0.1);
30
+ }
31
+ }
32
+
33
+ &::part(native) {
34
+ /**
35
+ * TODO: remove !important.
36
+ */
37
+ box-shadow: none !important;
38
+ border: none !important;
39
+ background: transparent !important;
40
+ backdrop-filter: none !important;
41
+ }
8
42
  }
9
- &:last-child {
10
- margin-right: 12px;
43
+
44
+ ion-button:not(.ios26-disabled) {
45
+ margin: 0;
46
+ :first-child {
47
+ margin-left: -8px;
48
+ }
49
+ :last-child {
50
+ margin-right: -8px;
51
+ }
52
+ :only-child {
53
+ margin: 0;
54
+ }
11
55
  }
12
56
 
57
+ :has(ion-back-button) {
58
+ margin: 0;
59
+ }
60
+ }
61
+
62
+ @mixin theme-button() {
63
+ max-height: inherit;
64
+
13
65
  transition:
14
66
  transform 100ms ease-out,
15
67
  color 50ms ease;
16
68
  will-change: transform;
17
69
 
18
- &.ion-activated {
19
- transform: scale(1.2);
20
- box-shadow: none;
21
- ion-icon {
22
- // 色を指定しなくても半透明に
23
- //color: var(--ion-color-medium-tint);
24
- }
25
- }
26
-
27
70
  // button size default
28
- font-size: 1.05rem;
29
- &:not(.button-has-icon-only):not(.back-button-has-icon-only)::part(native) {
30
- padding: 0 16px;
31
- min-height: 44px;
32
- }
33
-
34
- &.button-small {
35
- font-size: 1.04rem;
71
+ &:not(.button-small):not(.button-large) {
72
+ font-size: 1.05rem;
36
73
  &:not(.button-has-icon-only):not(.back-button-has-icon-only)::part(native) {
37
- padding: 0 12px;
38
- min-height: 36px;
74
+ padding: 0 16px;
75
+ min-height: 44px;
39
76
  }
40
77
  }
41
78
 
79
+ --border-radius: 24px !important;
42
80
  &.button-large {
43
- font-size: 1.06rem;
44
- &:not(.button-has-icon-only):not(.back-button-has-icon-only)::part(native) {
45
- padding: 0 20px;
46
- min-height: 52px;
47
- }
81
+ --border-radius: 30px !important;
48
82
  }
49
83
 
50
- &::part(native) {
51
- border-radius: 25px;
84
+ &:not(.button-clear):not(.ios26-button-clear) {
85
+ &.ion-activated {
86
+ transform: scale(0.95);
87
+ &.button-small {
88
+ transform: scale(0.94);
89
+ }
90
+ &.button-large {
91
+ transform: scale(0.96);
92
+ }
93
+ }
52
94
  }
53
95
 
96
+ // fill:default only
54
97
  &:not(.button-solid):not(.ios26-button-solid):not(.button-outline):not(.ios26-button-outline):not(.button-clear):not(
55
98
  .ios26-button-clear
56
- )::part(native) {
57
- @include api.glass-background;
58
- border-radius: 25px;
59
- }
99
+ ) {
100
+ --background-hover: transparent;
101
+ --background-activated: transparent;
102
+ &::part(native) {
103
+ @include api.glass-background;
104
+ }
105
+
106
+ &:not(.button-disabled) {
107
+ opacity: 1; // for ion-back-button
108
+ }
60
109
 
61
- &:not(.button-solid):not(.ios26-button-solid):not(.button-clear):not(.ios26-button-clear) {
62
- color: var(--color);
110
+ --color: rgba(var(--ion-text-color-rgb, 0, 0, 0), 1);
111
+ &.ion-color {
112
+ --color: rgba(var(--ion-color-base-rgb, var(--ion-text-color-rgb, 0, 0, 0)), 1);
113
+ }
63
114
  &.ion-activated {
115
+ --color: rgba(var(--ion-text-color-rgb, 0, 0, 0), 0.1);
116
+ &.ion-color {
117
+ --color: rgba(var(--ion-color-base-rgb, var(--ion-text-color-rgb, 0, 0, 0)), 0.1);
118
+ }
119
+ transform: scale(1.28);
120
+ &.button-large {
121
+ transform: scale(1.18);
122
+ }
64
123
  &::part(native) {
65
- &::after {
66
- background: transparent !important;
67
- }
124
+ opacity: 1; // for ion-back-button
68
125
  }
69
126
  }
70
127
  }
71
128
 
72
129
  &.button-has-icon-only,
73
130
  &.back-button-has-icon-only {
74
- &::part(native) {
75
- border-radius: 50%;
131
+ border-radius: 50%;
132
+ &:not(.button-small):not(.button-large)::part(native) {
76
133
  width: 44px;
77
134
  height: 44px;
78
135
  padding: 2px;
79
136
  }
80
137
 
81
138
  ion-icon {
82
- font-size: 1.4rem !important;
139
+ font-size: 1.4rem;
83
140
  &[name='close-outline'] {
84
- font-size: 2rem !important;
141
+ font-size: 2rem;
85
142
  }
86
143
  }
87
144
  }
88
145
  }
89
146
 
90
- /**
91
- * .ios26-no-liquid-glass を適用しない限り、デフォルトスタイル
92
- */
93
- ion-header.ios,
94
- ion-footer.ios {
95
- ion-buttons:not(.ios26-no-liquid-glass) ion-button:not(.ios26-no-liquid-glass),
96
- ion-buttons:not(.ios26-no-liquid-glass) ion-back-button:not(.ios26-no-liquid-glass),
97
- /* collapseのanimateBackButton対策 */
98
- ion-back-button:not(.ios26-no-liquid-glass) {
147
+ ion-buttons.ios:not(.ios26-disabled) {
148
+ @include theme-buttons;
149
+ ion-button:not(.ios26-disabled),
150
+ ion-back-button:not(.ios26-disabled) {
99
151
  @include theme-button;
100
152
  }
101
153
  }
102
154
 
103
- /**
104
- * .ios26-liquid-glass を任意で適用した場合のスタイル
105
- */
106
- ion-buttons.ios.ios26-liquid-glass ion-button:not(.ios26-no-liquid-glass),
107
- ion-buttons.ios.ios26-liquid-glass ion-back-button:not(.ios26-no-liquid-glass),
108
- ion-button.ios.ios26-liquid-glass,
109
- ion-back-button.ios.ios26-liquid-glass {
155
+ ion-button.ios:not(.ios26-disabled) {
156
+ @include theme-button;
157
+ }
158
+ ion-back-button.ios:not(.ios26-disabled) {
110
159
  @include theme-button;
111
160
  }
@@ -1,3 +1,7 @@
1
- ion-card.ios {
1
+ ion-card.ios:not(.ios26-disabled) {
2
2
  border-radius: 24px;
3
+
4
+ ion-list ion-item {
5
+ --padding-start: 0;
6
+ }
3
7
  }
@@ -0,0 +1,10 @@
1
+ @use '../utils/api';
2
+
3
+ ion-chip.ios:not(.ios26-disabled) {
4
+ @include api.glass-background;
5
+
6
+ transition: transform 100ms ease-out;
7
+ &.ion-activated {
8
+ transform: scale(1.18);
9
+ }
10
+ }
@@ -0,0 +1,13 @@
1
+ .ios:not(.ios26-disabled) {
2
+ /**
3
+ * iOS26から上下のセーフエリアいっぱいまでコンテンツを表示するようになったため、
4
+ * コンテンツのmarginとpaddingを調整します。なお、Angular CDK Scrollingにも対応しています。
5
+ */
6
+ .ion-page:not(:has(ion-footer)) ion-content cdk-virtual-scroll-viewport {
7
+ margin-bottom: calc(calc(56px + var(--ios26-floating-safe-area-bottom)) * -1);
8
+ padding-bottom: calc(56px + var(--ios26-floating-safe-area-bottom));
9
+ }
10
+ ion-content:not(:has(cdk-virtual-scroll-viewport)) {
11
+ --padding-bottom: calc(56px + var(--ios26-floating-safe-area-bottom));
12
+ }
13
+ }
@@ -0,0 +1,9 @@
1
+ @use '../utils/api';
2
+
3
+ ion-datetime.ios:not(.ios26-disabled) {
4
+ @include api.glass-background;
5
+ border-radius: 24px;
6
+
7
+ --wheel-highlight-background: transparent !important;
8
+ --wheel-highlight-border-radius: 24px !important;
9
+ }
@@ -1,6 +1,6 @@
1
1
  @use '../utils/api';
2
2
 
3
- ion-fab.ios {
3
+ ion-fab.ios:not(.ios26-disabled) {
4
4
  ion-fab-button {
5
5
  &::part(native) {
6
6
  @include api.glass-background;
@@ -8,9 +8,15 @@ ion-fab.ios {
8
8
  }
9
9
  --background-activated: rgba(var(--ios26-color-light-rgb), 0.3);
10
10
  }
11
- // TODO: これはUtility Classにマイグレートする必要があります
12
- &.inner-tab-bar {
13
- right: calc(16px + var(--ion-safe-area-right, 0px));
11
+ &.fab-vertical-bottom {
14
12
  bottom: var(--ios26-floating-safe-area-bottom);
15
13
  }
14
+
15
+ &.fab-horizontal-start {
16
+ right: calc(16px + var(--ion-safe-area-left, 0px));
17
+ }
18
+
19
+ &.fab-horizontal-end {
20
+ right: calc(16px + var(--ion-safe-area-right, 0px));
21
+ }
16
22
  }
@@ -1,10 +1,17 @@
1
1
  @use '../utils/theme-list-inset';
2
2
 
3
- ion-list.list-inset.ios {
3
+ ion-list.list-inset.ios:not(.ios26-disabled) {
4
4
  @include theme-list-inset.ion-list-inset();
5
5
 
6
- ion-item-group,
6
+ ion-radio-group,
7
7
  ion-reorder-group {
8
+ display: block;
9
+ }
10
+
11
+ ion-item-group,
12
+ ion-reorder-group,
13
+ ion-accordion-group,
14
+ ion-radio-group {
8
15
  border-radius: 24px;
9
16
  overflow: hidden;
10
17
 
@@ -0,0 +1,9 @@
1
+ @use '../utils/api';
2
+
3
+ ion-loading.ios:not(.ios26-disabled) {
4
+ --backdrop-opacity: 0.2;
5
+ .loading-wrapper {
6
+ @include api.glass-background;
7
+ border-radius: 24px;
8
+ }
9
+ }
@@ -1,6 +1,31 @@
1
- ion-modal.ios {
1
+ @use '../utils/api';
2
+
3
+ ion-modal.ios:not(.ios26-disabled) {
4
+ --backdrop-opacity: 0.2;
2
5
  ion-toolbar {
3
6
  padding-right: calc(var(--ion-safe-area-right) + 4px) !important;
4
7
  padding-left: calc(var(--ion-safe-area-left) + 4px) !important;
5
8
  }
9
+ &::part(handle) {
10
+ width: 80px;
11
+ }
12
+
13
+ &.modal-card {
14
+ /**
15
+ * IonicでCardModalのborder-radiusはハードコーディングされています。
16
+ * また、iOS26のドキュメントで見つからないため、サポートは行いません。
17
+ * https://github.com/ionic-team/ionic-framework/blob/3b80473f2fd5ad4da5a9f5d66f783a69909c8965/core/src/components/modal/animations/ios.enter.ts#L82-L83
18
+ */
19
+ }
20
+
21
+ &:has(.ion-delegate-host):has(ion-datetime) {
22
+ --border-radius: 24px;
23
+ }
24
+
25
+ &.modal-sheet {
26
+ --border-radius: 30px;
27
+ &::part(content) {
28
+ @include api.glass-background(1);
29
+ }
30
+ }
6
31
  }
@@ -0,0 +1,4 @@
1
+ @use '../utils/api';
2
+
3
+ ion-picker.ios:not(.ios26-disabled) {
4
+ }
@@ -1,21 +1,13 @@
1
1
  @use '../utils/api';
2
2
 
3
- ion-popover.ios {
4
- --backdrop-opacity: 0.04;
5
- &::part(arrow) {
6
- //display: none;
3
+ ion-popover.ios:not(.ios26-disabled) {
4
+ --backdrop-opacity: 0.2;
5
+ &::part(arrow)::after {
6
+ @include api.glass-background;
7
7
  }
8
- &:not(.ios26-no-liquid-glass) {
9
- &::part(content) {
10
- @include api.glass-background(0.6);
11
- border-radius: 24px;
12
- padding: 0;
13
- }
14
- }
15
- ion-list {
16
- background: transparent;
17
- ion-item {
18
- --background: transparent;
19
- }
8
+ &::part(content) {
9
+ @include api.glass-background;
10
+ border-radius: 24px;
11
+ padding: 0;
20
12
  }
21
13
  }
@@ -0,0 +1,21 @@
1
+ @use '../utils/api';
2
+
3
+ ion-range.ios:not(.ios26-disabled) {
4
+ --knob-size: 20px;
5
+ --knob-border-radius: 24px;
6
+ padding-right: 36px;
7
+
8
+ &::part(knob) {
9
+ width: 38px;
10
+ transition: transform 0.3s ease;
11
+ }
12
+ &.range-pressed::part(knob) {
13
+ transform: scale(1.4, 1.6) translateX(calc(38px * -0.1));
14
+ @include api.glass-background(0.1, 0.5px, 120%);
15
+ box-shadow:
16
+ inset 0 8px 8px -8px var(--bar-background),
17
+ inset 0 -8px 8px -8px var(--bar-background),
18
+ inset 8px 0 8px -8px var(--bar-background),
19
+ inset -8px 0 8px -8px var(--bar-background);
20
+ }
21
+ }
@@ -1,7 +1,7 @@
1
1
  @use '../utils/api';
2
2
 
3
3
  ion-modal.ios {
4
- ion-searchbar:not(.ios26-no-liquid-glass) {
4
+ ion-searchbar:not(.ios26-disabled) {
5
5
  .searchbar-input-container {
6
6
  margin: 0 6px;
7
7
  input.searchbar-input {
@@ -12,7 +12,7 @@ ion-modal.ios {
12
12
  }
13
13
  }
14
14
 
15
- ion-searchbar.ios:not(.ios26-no-liquid-glass) {
15
+ ion-searchbar.ios:not(.ios26-disabled) {
16
16
  min-height: 60px;
17
17
  padding: 0;
18
18
 
@@ -1,10 +1,45 @@
1
- ion-toolbar.ios {
1
+ @use '../utils/api';
2
+
3
+ ion-toolbar.ios:not(.ios26-disabled) {
4
+ &:has(ion-segment) {
5
+ overflow: visible;
6
+ }
2
7
  ion-segment {
3
- width: calc(100% - 24px);
4
- border-radius: 16px;
8
+ @include api.glass-background;
9
+ min-height: 44px;
10
+ border-radius: 25px;
11
+
12
+ transition: transform 100ms ease-out;
13
+ will-change: transform;
14
+ overflow: visible;
15
+
16
+ ion-segment-button {
17
+ --border-width: 0;
18
+
19
+ &::part(indicator-background) {
20
+ border-radius: 25px;
21
+ box-shadow: none;
22
+ background: rgba(var(--ion-text-color-rgb, 0, 0, 0), 0.06);
23
+ }
24
+ }
25
+
26
+ &.segment-activated {
27
+ transform: scale(1.1);
28
+ overflow: visible;
5
29
 
6
- ion-segment-button::part(indicator-background) {
7
- border-radius: 16px;
30
+ ion-segment-button {
31
+ transition: transform 100ms ease-out;
32
+ &.segment-button-checked {
33
+ transform: scale(1.1);
34
+ }
35
+ &::part(indicator-background) {
36
+ position: relative;
37
+ z-index: 1;
38
+ @include api.glass-background;
39
+ transform: scale(1.1);
40
+ transform-origin: center center;
41
+ }
42
+ }
8
43
  }
9
44
  }
10
45
  }
@@ -1,18 +1,33 @@
1
1
  @use '../utils/api';
2
2
 
3
- ion-tab-bar.ios {
3
+ ion-tab-bar.ios:not(.ios26-disabled) {
4
4
  @include api.glass-background;
5
5
  z-index: 2;
6
6
 
7
7
  border-radius: 40px;
8
8
 
9
- width: calc(100% - 56px - 16px - 16px - 4px - 16px);
10
- max-width: 400px;
9
+ &[slot='top'] {
10
+ position: absolute;
11
+ top: var(--ios26-floating-safe-area-top);
12
+ right: calc(16px + var(--ion-safe-area-right, 0px));
13
+ }
14
+
15
+ &[slot='bottom'] {
16
+ position: absolute;
17
+ bottom: var(--ios26-floating-safe-area-bottom);
18
+ left: calc(16px + var(--ion-safe-area-left, 0px));
19
+ }
20
+
21
+ /**
22
+ * 100% - margin-left - margin-right - right-fab - margin-right-fab
23
+ */
24
+ width: calc(100% - calc(18px + var(--ion-safe-area-left, 0px)) - calc(18px + var(--ion-safe-area-left, 0px)) - 54px - 18px);
25
+ max-width: 474px;
26
+ &:has(:nth-child(5)) {
27
+ width: calc(100% - calc(18px + var(--ion-safe-area-left, 0px)) - calc(18px + var(--ion-safe-area-left, 0px)));
28
+ max-width: 546px;
29
+ }
11
30
  padding: 2px 2px;
12
- bottom: var(--ios26-floating-safe-area-bottom);
13
- left: calc(16px + var(--ion-safe-area-left, 0px));
14
- position: absolute;
15
- margin: auto;
16
31
 
17
32
  transition: transform 100ms ease-out;
18
33
  will-change: transform;
@@ -34,7 +49,7 @@ ion-tab-bar.ios {
34
49
  &.tab-selected {
35
50
  &::part(native) {
36
51
  backdrop-filter: blur(7px);
37
- background: rgba(var(--ios26-color-tab-active-rgb), 0.1);
52
+ background: rgba(var(--ios26-color-tab-active-rgb), 0.095);
38
53
  transition: background 0.2s ease;
39
54
  border-radius: 32px;
40
55
  }
@@ -1,3 +1,12 @@
1
- ion-toast.ios {
2
- --border-radius: 24px;
1
+ @use '../utils/api';
2
+
3
+ ion-toast.ios:not(.ios26-disabled) {
4
+ --background: transparent;
5
+ --start: 16px;
6
+ --end: 16px;
7
+
8
+ &::part(container) {
9
+ @include api.glass-background;
10
+ border-radius: 24px;
11
+ }
3
12
  }
@@ -1,47 +1,56 @@
1
1
  @use '../utils/api';
2
2
 
3
- @keyframes activate-animation {
4
- 0% {
5
- transform: scale(0);
6
- }
7
- 100% {
8
- transform: scale(1.2, 1.6);
9
- }
10
- }
11
-
12
- @keyframes deactivate-animation {
13
- 0% {
14
- transform: scale(1.2, 1.6);
3
+ /**
4
+ * Adjustments have been made to prevent the right edge from being cut off within the ion-item.
5
+ * When the native-inner part be added to the ion-item, it will be removed.
6
+ */
7
+ ion-item.ios:not(.ios26-disabled) ion-toggle.ios:not(.ios26-disabled) {
8
+ &.toggle-checked.toggle-activated::part(track) {
9
+ transform-origin: left;
10
+ transform: scaleX(0.894);
15
11
  }
16
- 100% {
17
- transform: scale(0);
12
+ &.toggle-activated::part(handle) {
13
+ transform: scale(1.4, 1.6) translateX(calc(38px * -0.15));
18
14
  }
19
15
  }
20
16
 
21
- ion-toggle.ios {
17
+ ion-toggle.ios:not(.ios26-disabled) {
22
18
  --handle-width: 38px;
23
19
  --handle-height: 24px;
24
20
  --handle-max-width: none;
25
21
  --handle-max-height: none;
26
22
  --track-background: rgba(var(--ion-text-color-rgb, 0, 0, 0), 0.23);
27
- ::part(handle) {
28
- transition: transform 0.3s ease;
29
- }
30
- &.toggle-activated::part(handle) {
31
- transform: scale(1.2, 1.6) translateX(calc(38px * -0.1));
32
- @include api.glass-background(0.1, 0.5px, 120%);
33
- box-shadow:
34
- inset 0 0 4px 0 rgba(var(--ios26-color-shadow-rgb), 0.2),
35
- 0 0 6px 0 rgba(var(--ios26-color-shadow-rgb), 0.8);
36
- }
37
23
  &::part(track) {
38
24
  overflow: visible;
39
25
  width: 64px;
40
26
  height: 28px;
41
27
  transition: transform 0.3s ease;
42
28
  }
43
- &.toggle-checked.toggle-activated::part(track) {
44
- transform-origin: left center;
45
- transform: scaleX(0.926);
29
+ &.toggle-activated:not(.toggle-checked)::part(handle) {
30
+ transform: translateX(-4px) scale(1.4, 1.6);
31
+ }
32
+ &.toggle-activated::part(handle) {
33
+ transform: scale(1.4, 1.6);
34
+ @include api.glass-background(0.1, 0.5px, 120%);
35
+ transition:
36
+ transform 300ms,
37
+ width 120ms ease-in-out 80ms,
38
+ left 110ms ease-in-out 80ms,
39
+ right 110ms ease-in-out 80ms;
40
+ box-shadow: inset 0 0 8px 0 var(--track-background);
41
+ }
42
+ &.ion-color.toggle-checked.toggle-activated::part(handle) {
43
+ box-shadow:
44
+ inset 0 8px 8px -8px var(--ion-color-base),
45
+ inset 8px 0 8px -8px var(--track-background),
46
+ inset 8px 0 8px -8px var(--track-background),
47
+ inset -8px 0 8px -8px var(--ion-color-base);
48
+ }
49
+ &.toggle-checked.toggle-activated::part(handle) {
50
+ box-shadow:
51
+ inset 0 8px 8px -8px var(--track-background-checked),
52
+ inset 8px 0 8px -8px var(--track-background),
53
+ inset 8px 0 8px -8px var(--track-background),
54
+ inset -8px 0 8px -8px var(--track-background-checked);
46
55
  }
47
56
  }