@rdlabo/ionic-theme-ios26 0.0.2 → 0.0.4

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 (205) hide show
  1. package/.cursor/rules/css-compilation.mdc +34 -0
  2. package/.cursor/rules/demo-application.mdc +39 -0
  3. package/.cursor/rules/development-workflow.mdc +41 -0
  4. package/.cursor/rules/project-role.mdc +21 -0
  5. package/.github/FUNDING.yml +15 -0
  6. package/.github/workflows/lint.yml +40 -0
  7. package/.husky/pre-commit +1 -0
  8. package/.lintstagedrc.yml +6 -0
  9. package/.prettierignore +3 -0
  10. package/FEEDBACK.md +118 -0
  11. package/FEEDBACK2.md +45 -0
  12. package/README.md +107 -75
  13. package/USING_ION_ITEM_GROUP.md +56 -0
  14. package/demo/ .cursor/rules/angular-20.mdc +136 -0
  15. package/demo/.browserslistrc +15 -0
  16. package/demo/.editorconfig +16 -0
  17. package/demo/.vscode/extensions.json +5 -0
  18. package/demo/.vscode/settings.json +3 -0
  19. package/demo/angular.json +141 -0
  20. package/demo/capacitor.config.ts +9 -0
  21. package/demo/eslint.config.js +49 -0
  22. package/demo/ionic.config.json +7 -0
  23. package/demo/karma.conf.js +44 -0
  24. package/demo/package-lock.json +20001 -0
  25. package/demo/package.json +60 -0
  26. package/demo/src/app/album/album-page.component.html +24 -0
  27. package/demo/src/app/album/album-page.component.scss +17 -0
  28. package/demo/src/app/album/album-page.component.spec.ts +21 -0
  29. package/demo/src/app/album/album-page.component.ts +24 -0
  30. package/demo/src/app/app.component.html +3 -0
  31. package/demo/src/app/app.component.ts +16 -0
  32. package/demo/src/app/app.config.ts +17 -0
  33. package/demo/src/app/app.routes.ts +8 -0
  34. package/demo/src/app/health/health-page.component.html +17 -0
  35. package/demo/src/app/health/health-page.component.scss +0 -0
  36. package/demo/src/app/health/health-page.component.spec.ts +21 -0
  37. package/demo/src/app/health/health-page.component.ts +14 -0
  38. package/demo/src/app/index/index-page.component.html +49 -0
  39. package/demo/src/app/index/index-page.component.scss +0 -0
  40. package/demo/src/app/index/index-page.component.spec.ts +21 -0
  41. package/demo/src/app/index/index-page.component.ts +100 -0
  42. package/demo/src/app/index/index.routes.ts +89 -0
  43. package/demo/src/app/index/pages/action-sheet/action-sheet.page.html +33 -0
  44. package/demo/src/app/index/pages/action-sheet/action-sheet.page.scss +0 -0
  45. package/demo/src/app/index/pages/action-sheet/action-sheet.page.spec.ts +21 -0
  46. package/demo/src/app/index/pages/action-sheet/action-sheet.page.ts +73 -0
  47. package/demo/src/app/index/pages/action-sheet/action-sheet.util.ts +28 -0
  48. package/demo/src/app/index/pages/alert/alert.page.html +33 -0
  49. package/demo/src/app/index/pages/alert/alert.page.scss +0 -0
  50. package/demo/src/app/index/pages/alert/alert.page.spec.ts +21 -0
  51. package/demo/src/app/index/pages/alert/alert.page.ts +73 -0
  52. package/demo/src/app/index/pages/alert/alert.util.ts +21 -0
  53. package/demo/src/app/index/pages/breadcrumbs/breadcrumbs.page.html +41 -0
  54. package/demo/src/app/index/pages/breadcrumbs/breadcrumbs.page.scss +0 -0
  55. package/demo/src/app/index/pages/breadcrumbs/breadcrumbs.page.spec.ts +21 -0
  56. package/demo/src/app/index/pages/breadcrumbs/breadcrumbs.page.ts +47 -0
  57. package/demo/src/app/index/pages/button/button.page.html +112 -0
  58. package/demo/src/app/index/pages/button/button.page.scss +3 -0
  59. package/demo/src/app/index/pages/button/button.page.spec.ts +21 -0
  60. package/demo/src/app/index/pages/button/button.page.ts +51 -0
  61. package/demo/src/app/index/pages/card/card.page.html +171 -0
  62. package/demo/src/app/index/pages/card/card.page.scss +0 -0
  63. package/demo/src/app/index/pages/card/card.page.spec.ts +21 -0
  64. package/demo/src/app/index/pages/card/card.page.ts +57 -0
  65. package/demo/src/app/index/pages/checkbox/checkbox.page.html +66 -0
  66. package/demo/src/app/index/pages/checkbox/checkbox.page.scss +0 -0
  67. package/demo/src/app/index/pages/checkbox/checkbox.page.spec.ts +21 -0
  68. package/demo/src/app/index/pages/checkbox/checkbox.page.ts +45 -0
  69. package/demo/src/app/index/pages/chip/chip.page.html +72 -0
  70. package/demo/src/app/index/pages/chip/chip.page.scss +0 -0
  71. package/demo/src/app/index/pages/chip/chip.page.spec.ts +21 -0
  72. package/demo/src/app/index/pages/chip/chip.page.ts +47 -0
  73. package/demo/src/app/index/pages/date-and-time-pickers/date-and-time-pickers.page.html +48 -0
  74. package/demo/src/app/index/pages/date-and-time-pickers/date-and-time-pickers.page.scss +0 -0
  75. package/demo/src/app/index/pages/date-and-time-pickers/date-and-time-pickers.page.spec.ts +21 -0
  76. package/demo/src/app/index/pages/date-and-time-pickers/date-and-time-pickers.page.ts +55 -0
  77. package/demo/src/app/index/pages/floating-action-button/floating-action-button.page.html +106 -0
  78. package/demo/src/app/index/pages/floating-action-button/floating-action-button.page.scss +0 -0
  79. package/demo/src/app/index/pages/floating-action-button/floating-action-button.page.spec.ts +21 -0
  80. package/demo/src/app/index/pages/floating-action-button/floating-action-button.page.ts +49 -0
  81. package/demo/src/app/index/pages/menu/menu.page.html +13 -0
  82. package/demo/src/app/index/pages/menu/menu.page.scss +0 -0
  83. package/demo/src/app/index/pages/menu/menu.page.spec.ts +21 -0
  84. package/demo/src/app/index/pages/menu/menu.page.ts +17 -0
  85. package/demo/src/app/index/pages/modal/modal.page.html +37 -0
  86. package/demo/src/app/index/pages/modal/modal.page.scss +0 -0
  87. package/demo/src/app/index/pages/modal/modal.page.spec.ts +21 -0
  88. package/demo/src/app/index/pages/modal/modal.page.ts +77 -0
  89. package/demo/src/app/index/pages/popover/popover.page.html +34 -0
  90. package/demo/src/app/index/pages/popover/popover.page.scss +0 -0
  91. package/demo/src/app/index/pages/popover/popover.page.spec.ts +21 -0
  92. package/demo/src/app/index/pages/popover/popover.page.ts +47 -0
  93. package/demo/src/app/index/pages/progress-indicators/progress-indicators.page.html +28 -0
  94. package/demo/src/app/index/pages/progress-indicators/progress-indicators.page.scss +0 -0
  95. package/demo/src/app/index/pages/progress-indicators/progress-indicators.page.spec.ts +21 -0
  96. package/demo/src/app/index/pages/progress-indicators/progress-indicators.page.ts +47 -0
  97. package/demo/src/app/index/pages/radio/radio.page.html +39 -0
  98. package/demo/src/app/index/pages/radio/radio.page.scss +0 -0
  99. package/demo/src/app/index/pages/radio/radio.page.spec.ts +21 -0
  100. package/demo/src/app/index/pages/radio/radio.page.ts +47 -0
  101. package/demo/src/app/index/pages/range/range.page.html +58 -0
  102. package/demo/src/app/index/pages/range/range.page.scss +0 -0
  103. package/demo/src/app/index/pages/range/range.page.spec.ts +21 -0
  104. package/demo/src/app/index/pages/range/range.page.ts +49 -0
  105. package/demo/src/app/index/pages/searchbar/searchbar.page.html +33 -0
  106. package/demo/src/app/index/pages/searchbar/searchbar.page.scss +0 -0
  107. package/demo/src/app/index/pages/searchbar/searchbar.page.spec.ts +21 -0
  108. package/demo/src/app/index/pages/searchbar/searchbar.page.ts +45 -0
  109. package/demo/src/app/index/pages/segment/segment.page.html +102 -0
  110. package/demo/src/app/index/pages/segment/segment.page.scss +0 -0
  111. package/demo/src/app/index/pages/segment/segment.page.spec.ts +21 -0
  112. package/demo/src/app/index/pages/segment/segment.page.ts +51 -0
  113. package/demo/src/app/index/pages/select/select.page.html +74 -0
  114. package/demo/src/app/index/pages/select/select.page.scss +0 -0
  115. package/demo/src/app/index/pages/select/select.page.spec.ts +21 -0
  116. package/demo/src/app/index/pages/select/select.page.ts +50 -0
  117. package/demo/src/app/index/pages/toast/toast.page.html +32 -0
  118. package/demo/src/app/index/pages/toast/toast.page.scss +0 -0
  119. package/demo/src/app/index/pages/toast/toast.page.spec.ts +21 -0
  120. package/demo/src/app/index/pages/toast/toast.page.ts +66 -0
  121. package/demo/src/app/index/pages/toggle/toggle.page.html +45 -0
  122. package/demo/src/app/index/pages/toggle/toggle.page.scss +0 -0
  123. package/demo/src/app/index/pages/toggle/toggle.page.spec.ts +21 -0
  124. package/demo/src/app/index/pages/toggle/toggle.page.ts +49 -0
  125. package/demo/src/app/settings/settings-page.component.html +117 -0
  126. package/demo/src/app/settings/settings-page.component.scss +33 -0
  127. package/demo/src/app/settings/settings-page.component.spec.ts +21 -0
  128. package/demo/src/app/settings/settings-page.component.ts +55 -0
  129. package/demo/src/app/tabs/tabs.page.html +23 -0
  130. package/demo/src/app/tabs/tabs.page.scss +9 -0
  131. package/demo/src/app/tabs/tabs.page.spec.ts +26 -0
  132. package/demo/src/app/tabs/tabs.page.ts +28 -0
  133. package/demo/src/app/tabs/tabs.routes.ts +40 -0
  134. package/demo/src/assets/.gitkeep +0 -0
  135. package/demo/src/favicon.ico +0 -0
  136. package/demo/src/global.scss +65 -0
  137. package/demo/src/index.html +24 -0
  138. package/demo/src/main.ts +5 -0
  139. package/demo/src/test.ts +7 -0
  140. package/demo/src/theme/variables.scss +20 -0
  141. package/demo/tsconfig.app.json +14 -0
  142. package/demo/tsconfig.json +30 -0
  143. package/demo/tsconfig.spec.json +17 -0
  144. package/demo/util/mocks/angular/angular-delegate.ts +18 -0
  145. package/demo/util/mocks/angular/ion-router-outlet.ts +39 -0
  146. package/demo/util/mocks/angular/modal-controller.ts +7 -0
  147. package/demo/util/mocks/angular/nav-controller.ts +22 -0
  148. package/demo/util/mocks/angular/popover-controller.ts +7 -0
  149. package/demo/util/mocks/util/base.mock.ts +13 -0
  150. package/demo/util/mocks/util/overlay.ts +13 -0
  151. package/demo/util/test.config.ts +54 -0
  152. package/package.json +39 -11
  153. package/prettier.config.js +18 -0
  154. package/screenshots/ios26.png +0 -0
  155. package/screenshots/why-ion-list-inset.png +0 -0
  156. package/src/components/ion-action-sheet.scss +61 -0
  157. package/src/components/ion-alert.scss +46 -0
  158. package/src/components/ion-breadcrumbs.scss +24 -0
  159. package/src/components/ion-button.scss +154 -0
  160. package/src/components/ion-card.scss +7 -0
  161. package/src/components/ion-chip.scss +10 -0
  162. package/src/components/ion-content.scss +13 -0
  163. package/src/components/ion-datetime.scss +9 -0
  164. package/src/components/ion-fab.scss +22 -0
  165. package/src/components/ion-list.scss +38 -0
  166. package/src/components/ion-loading.scss +9 -0
  167. package/src/components/ion-modal.scss +31 -0
  168. package/src/components/ion-picker.scss +4 -0
  169. package/src/components/ion-popover.scss +13 -0
  170. package/src/components/ion-range.scss +21 -0
  171. package/src/components/ion-searchbar.scss +37 -0
  172. package/src/components/ion-segment.scss +45 -0
  173. package/src/components/ion-tabs.scss +47 -0
  174. package/src/components/ion-toast.scss +12 -0
  175. package/src/components/ion-toggle.scss +56 -0
  176. package/src/components/ion-toolbar.scss +27 -0
  177. package/src/default-variables.scss +12 -0
  178. package/src/ionic-theme-ios26-dark-always.scss +6 -0
  179. package/src/ionic-theme-ios26-dark-class.scss +6 -0
  180. package/src/ionic-theme-ios26-dark-system.scss +8 -0
  181. package/src/ionic-theme-ios26.scss +23 -0
  182. package/src/md-ion-list-inset.scss +19 -0
  183. package/src/utils/api.scss +21 -0
  184. package/src/utils/dark/ion-button.scss +45 -0
  185. package/src/utils/theme-dark.scss +16 -0
  186. package/src/utils/theme-list-inset.scss +96 -0
  187. package/src/utils/translucent.scss +71 -0
  188. package/tsconfig.json +5 -0
  189. package/css/ion-list-inset.css +0 -247
  190. package/css/ion-list-inset.css.map +0 -1
  191. package/css/ionic-theme-ios26.css +0 -349
  192. package/css/ionic-theme-ios26.css.map +0 -1
  193. package/fesm2022/rdlabo-ionic-theme-ios26.mjs +0 -4
  194. package/fesm2022/rdlabo-ionic-theme-ios26.mjs.map +0 -1
  195. package/index.d.ts +0 -3
  196. package/src/assets/ion-list-inset.scss +0 -198
  197. package/src/assets/ios-design/ion-button.scss +0 -68
  198. package/src/assets/ios-design/ion-popover.scss +0 -23
  199. package/src/assets/ios-design/ion-searchbar.scss +0 -44
  200. package/src/assets/ios-design/ion-segment.scss +0 -12
  201. package/src/assets/ios-design/ion-tabs.scss +0 -60
  202. package/src/assets/ios-design/ion-toggle.scss +0 -8
  203. package/src/assets/ios-design/ios-design-dark.scss +0 -28
  204. package/src/assets/ios-design.scss +0 -110
  205. package/src/assets/ios-variables.scss +0 -38
@@ -0,0 +1,45 @@
1
+ @use '../utils/api';
2
+
3
+ ion-toolbar.ios:not(.ios26-disabled) {
4
+ &:has(ion-segment) {
5
+ overflow: visible;
6
+ }
7
+ ion-segment {
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;
29
+
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
+ }
43
+ }
44
+ }
45
+ }
@@ -0,0 +1,47 @@
1
+ @use '../utils/api';
2
+
3
+ ion-tab-bar.ios:not(.ios26-disabled) {
4
+ @include api.glass-background;
5
+ z-index: 2;
6
+
7
+ border-radius: 40px;
8
+
9
+ width: calc(100% - 56px - 16px - 16px - 4px - 16px);
10
+ max-width: 400px;
11
+ 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
+
17
+ transition: transform 100ms ease-out;
18
+ will-change: transform;
19
+ &:active {
20
+ transform: scale(1.02);
21
+ backdrop-filter: saturate(360%);
22
+ }
23
+
24
+ ion-tab-button {
25
+ & > ion-icon {
26
+ font-size: 30px;
27
+ }
28
+ background: rgba(var(--ios26-color-light-rgb), 0);
29
+ height: auto;
30
+ &::part(native) {
31
+ overflow: visible;
32
+ }
33
+
34
+ &.tab-selected {
35
+ &::part(native) {
36
+ backdrop-filter: blur(7px);
37
+ background: rgba(var(--ios26-color-tab-active-rgb), 0.095);
38
+ transition: background 0.2s ease;
39
+ border-radius: 32px;
40
+ }
41
+
42
+ &.ion-activated::part(native) {
43
+ background: rgba(var(--ios26-color-shadow-rgb), 0.02);
44
+ }
45
+ }
46
+ }
47
+ }
@@ -0,0 +1,12 @@
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
+ }
12
+ }
@@ -0,0 +1,56 @@
1
+ @use '../utils/api';
2
+
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);
11
+ }
12
+ &.toggle-activated::part(handle) {
13
+ transform: scale(1.4, 1.6) translateX(calc(38px * -0.15));
14
+ }
15
+ }
16
+
17
+ ion-toggle.ios:not(.ios26-disabled) {
18
+ --handle-width: 38px;
19
+ --handle-height: 24px;
20
+ --handle-max-width: none;
21
+ --handle-max-height: none;
22
+ --track-background: rgba(var(--ion-text-color-rgb, 0, 0, 0), 0.23);
23
+ &::part(track) {
24
+ overflow: visible;
25
+ width: 64px;
26
+ height: 28px;
27
+ transition: transform 0.3s ease;
28
+ }
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);
55
+ }
56
+ }
@@ -0,0 +1,27 @@
1
+ @use 'ion-button';
2
+
3
+ /**
4
+ * https://github.com/ionic-team/ionic-framework/blob/main/core/src/components/header/header.scss#L17-L19
5
+ * ion-header ion-toolbar:first-of-type {
6
+ * padding-top: var(--ion-safe-area-top, 0);
7
+ * }
8
+ */
9
+ ion-header.ios:not(.ios26-disabled) ion-toolbar:not(.ios26-disabled):first-of-type {
10
+ padding-top: max(calc(var(--ion-safe-area-top) - 12px), 4px);
11
+ }
12
+
13
+ ion-toolbar.ios:not(.toolbar-title-large):not(.ios26-disabled) {
14
+ --min-height: 68px;
15
+ }
16
+
17
+ ion-header.ios:not(.ios26-disabled),
18
+ ion-footer.ios:not(.ios26-disabled) {
19
+ ion-buttons {
20
+ margin-left: calc(12px + var(--ion-safe-area-left));
21
+ margin-right: calc(12px + var(--ion-safe-area-right));
22
+ }
23
+ ion-back-button {
24
+ margin-left: calc(12px + var(--ion-safe-area-left));
25
+ margin-right: calc(12px + var(--ion-safe-area-right));
26
+ }
27
+ }
@@ -0,0 +1,12 @@
1
+ :root {
2
+ --ios26-floating-safe-area-bottom: max(10px, var(--ion-safe-area-bottom, 0px));
3
+ --ios26-content-box-shadow-opacity: 0.8;
4
+
5
+ --ios26-color-dark-rgb: 0, 0, 0;
6
+ --ios26-color-light-rgb: 255, 255, 255;
7
+ --ios26-color-tab-active-rgb: 16, 16, 16;
8
+ --ios26-color-inner-shadow-rgb: 224, 224, 224;
9
+ --ios26-color-outer-shadow-rgb: 224, 224, 224;
10
+ --ios26-color-background-rgb: 255, 255, 255;
11
+ --ios26-color-edge-rgb: 255, 255, 255;
12
+ }
@@ -0,0 +1,6 @@
1
+ @use 'utils/theme-dark';
2
+
3
+ :root {
4
+ @include theme-dark.default-variables;
5
+ }
6
+ @include theme-dark.theme-dark;
@@ -0,0 +1,6 @@
1
+ @use 'utils/theme-dark';
2
+
3
+ .ion-palette-dark {
4
+ @include theme-dark.default-variables;
5
+ @include theme-dark.theme-dark;
6
+ }
@@ -0,0 +1,8 @@
1
+ @use 'utils/theme-dark';
2
+
3
+ @media (prefers-color-scheme: dark) {
4
+ :root {
5
+ @include theme-dark.default-variables;
6
+ }
7
+ @include theme-dark.theme-dark;
8
+ }
@@ -0,0 +1,23 @@
1
+ @use 'utils/translucent';
2
+
3
+ @use 'components/ion-action-sheet';
4
+ @use 'components/ion-alert';
5
+ @use 'components/ion-breadcrumbs';
6
+ @use 'components/ion-button';
7
+ @use 'components/ion-card';
8
+ @use 'components/ion-chip';
9
+ @use 'components/ion-content';
10
+ @use 'components/ion-datetime';
11
+ @use 'components/ion-fab';
12
+ @use 'components/ion-list';
13
+ @use 'components/ion-loading';
14
+ @use 'components/ion-modal';
15
+ @use 'components/ion-picker';
16
+ @use 'components/ion-popover';
17
+ @use 'components/ion-range';
18
+ @use 'components/ion-searchbar';
19
+ @use 'components/ion-segment';
20
+ @use 'components/ion-tabs';
21
+ @use 'components/ion-toast';
22
+ @use 'components/ion-toggle';
23
+ @use 'components/ion-toolbar';
@@ -0,0 +1,19 @@
1
+ @use 'utils/theme-list-inset';
2
+
3
+ ion-list.list-inset.md {
4
+ @include theme-list-inset.ion-list-inset();
5
+
6
+ ion-item-group > ion-item {
7
+ & > ion-input[labelplacement='floating'] {
8
+ transition: transform 0.2s ease;
9
+
10
+ &:not(.label-floating) {
11
+ transform: translateY(-7px);
12
+ }
13
+
14
+ &.label-floating {
15
+ transform: translateY(-4px);
16
+ }
17
+ }
18
+ }
19
+ }
@@ -0,0 +1,21 @@
1
+ @mixin glass-background($opacity: 0.7, $blur: 2px, $saturate: 360%) {
2
+ background: rgba(var(--ios26-color-light-rgb), $opacity);
3
+ backdrop-filter: blur($blur) saturate($saturate);
4
+ box-shadow:
5
+ inset 0 0 8px 0 rgba(var(--ios26-color-inner-shadow-rgb), 0.2),
6
+ 0 0 12px 0 rgba(var(--ios26-color-outer-shadow-rgb), 0.82);
7
+ border-top: 0.5px solid rgba(var(--ios26-color-edge-rgb), 1);
8
+ border-right: 0.5px solid rgba(var(--ios26-color-edge-rgb), 0.8);
9
+ border-bottom: 0.5px solid rgba(var(--ios26-color-edge-rgb), 1);
10
+ border-left: 0.5px solid rgba(var(--ios26-color-edge-rgb), 0.6);
11
+ }
12
+
13
+ @mixin glass-background-dark-active($opacity: 0.4, $blur: 7px, $saturate: 180%) {
14
+ background: rgba(var(--ios26-color-tab-active-rgb), $opacity);
15
+ backdrop-filter: blur($blur) saturate($saturate);
16
+ box-shadow: none;
17
+ border-top: 0.5px solid rgba(var(--ios26-color-tab-active-rgb), 0.4);
18
+ border-right: 0.5px solid rgba(var(--ios26-color-tab-active-rgb), 0.2);
19
+ border-bottom: 0.5px solid rgba(var(--ios26-color-tab-active-rgb), 0.4);
20
+ border-left: 0.5px solid rgba(var(--ios26-color-tab-active-rgb), 0.3);
21
+ }
@@ -0,0 +1,45 @@
1
+ @use '../api';
2
+
3
+ @mixin theme-dark-buttons {
4
+ &:has(.ion-activated) {
5
+ @include api.glass-background-dark-active;
6
+ }
7
+
8
+ ion-button:not(.ios26-disabled),
9
+ ion-back-button:not(.ios26-disabled) {
10
+ &.ion-activated {
11
+ --color: rgba(var(--ion-text-color-rgb, 0, 0, 0), 1);
12
+
13
+ &.ion-color {
14
+ --color: rgba(var(--ion-color-base-rgb, var(--ion-text-color-rgb, 0, 0, 0)), 1);
15
+ }
16
+ }
17
+ }
18
+ }
19
+
20
+ @mixin theme-dark-button {
21
+ &.ion-activated:not(.button-solid):not(.ios26-button-solid):not(.button-outline):not(.ios26-button-outline):not(.button-clear):not(
22
+ .ios26-button-clear
23
+ ) {
24
+ --color: rgba(var(--ion-text-color-rgb, 0, 0, 0), 1);
25
+ &.ion-color {
26
+ --color: rgba(var(--ion-color-base-rgb, var(--ion-text-color-rgb, 0, 0, 0)), 1);
27
+ }
28
+ &::part(native) {
29
+ @include api.glass-background-dark-active;
30
+ }
31
+ ion-icon {
32
+ color: rgb(255, 255, 255) !important;
33
+ }
34
+ }
35
+ }
36
+
37
+ @mixin ion-button {
38
+ ion-buttons:not(.ios26-disabled) {
39
+ @include theme-dark-buttons;
40
+ }
41
+ ion-button:not(.ios26-disabled),
42
+ ion-back-button:not(.ios26-disabled) {
43
+ @include theme-dark-button;
44
+ }
45
+ }
@@ -0,0 +1,16 @@
1
+ @forward 'dark/ion-button';
2
+ @use 'dark/ion-button' as *;
3
+
4
+ @mixin default-variables {
5
+ --ios26-color-dark-rgb: 255, 255, 255;
6
+ --ios26-color-light-rgb: 58, 58, 58;
7
+ --ios26-color-tab-active-rgb: 255, 255, 255;
8
+ --ios26-color-inner-shadow-rgb: translarent;
9
+ --ios26-color-outer-shadow-rgb: translarent;
10
+ --ios26-color-background-rgb: 0, 0, 0;
11
+ --ios26-color-edge-rgb: 64, 64, 64;
12
+ }
13
+
14
+ @mixin theme-dark {
15
+ @include ion-button;
16
+ }
@@ -0,0 +1,96 @@
1
+ @mixin ion-list-inset() {
2
+ background: transparent;
3
+
4
+ ion-list-header {
5
+ display: flex;
6
+ align-items: center;
7
+
8
+ ion-label {
9
+ font-size: 0.9rem;
10
+ margin: 8px 4px 4px;
11
+ color: var(--ion-color-medium-tint);
12
+ }
13
+
14
+ ion-button {
15
+ margin-top: 8px;
16
+ }
17
+
18
+ ion-note {
19
+ font-size: 0.9rem;
20
+ margin: 8px 16px 4px 0;
21
+ }
22
+ }
23
+
24
+ // TODO: これはUtility Classにマイグレートする必要があります
25
+ ion-item-group.header-item-group {
26
+ & > ion-item > ion-label {
27
+ width: 100%;
28
+ text-align: center;
29
+ padding: 32px 16px 16px;
30
+
31
+ /**
32
+ * ion-header.header-collapse-condenseを使って、スクロールによってHeaderを変化させるトリック
33
+ */
34
+ ion-header.header-collapse-condense > ion-toolbar {
35
+ --min-height: 0;
36
+ visibility: hidden;
37
+ }
38
+
39
+ ion-icon {
40
+ font-size: 2.8rem;
41
+ color: #ffffff;
42
+ border-radius: 20%;
43
+ padding: 6px;
44
+ }
45
+
46
+ h2 {
47
+ font-size: 1.2rem;
48
+ font-weight: bold;
49
+ margin-top: 8px;
50
+ }
51
+
52
+ ion-text {
53
+ font-size: 0.9rem;
54
+ }
55
+ }
56
+ }
57
+
58
+ ion-item-group,
59
+ ion-reorder-group,
60
+ ion-radio-group {
61
+ ion-item {
62
+ ion-text[slot='end'] {
63
+ padding-left: 8px;
64
+ }
65
+
66
+ &.item-disabled {
67
+ opacity: 1;
68
+
69
+ & > * {
70
+ opacity: 0.4;
71
+ }
72
+
73
+ &::part(detail-icon) {
74
+ opacity: 0.1;
75
+ }
76
+ }
77
+
78
+ ion-button[slot='end'] {
79
+ &.ion-align-self-end {
80
+ transform: translateY(-7px);
81
+ }
82
+ ion-icon[slot='icon-only'] {
83
+ font-size: 1.2rem !important;
84
+ transform: translateY(4px);
85
+ }
86
+ }
87
+ }
88
+ }
89
+
90
+ & > ion-note {
91
+ color: var(--ion-color-medium-tint);
92
+ font-size: 0.9rem;
93
+ display: block;
94
+ margin: 8px 16px 8px 20px;
95
+ }
96
+ }
@@ -0,0 +1,71 @@
1
+ @use 'api';
2
+
3
+ ion-header.ios:not(.ios26-disabled).header-translucent,
4
+ ion-footer.ios:not(.ios26-disabled).footer-translucent {
5
+ .header-background,
6
+ .footer-background {
7
+ backdrop-filter: none;
8
+ }
9
+
10
+ ion-toolbar {
11
+ --border-width: 0;
12
+ --background: transparent;
13
+ /**
14
+ * TODO: Not expect work.
15
+ * https://github.com/ionic-team/ionic-framework/blob/3b80473f2fd5ad4da5a9f5d66f783a69909c8965/core/src/utils/transition/ios.transition.ts#L829C51-L829C60
16
+ * --opacity: 0;
17
+ */
18
+ .toolbar-background {
19
+ background: transparent !important;
20
+ }
21
+ ion-title {
22
+ filter: blur(0);
23
+ transform: translateY(0);
24
+ }
25
+ }
26
+ }
27
+
28
+ ion-header.ios:not(.ios26-disabled).header-collapse-main ion-toolbar.in-toolbar ion-title,
29
+ ion-header.ios:not(.ios26-disabled).header-collapse-main ion-toolbar.in-toolbar ion-buttons {
30
+ transition: all 0.5s ease-in-out;
31
+ }
32
+
33
+ ion-header.ios:not(.ios26-disabled).header-collapse-condense-inactive:not(.header-collapse-condense) ion-toolbar.in-toolbar ion-title,
34
+ ion-header.ios:not(.ios26-disabled).header-collapse-condense-inactive:not(.header-collapse-condense)
35
+ ion-toolbar.in-toolbar
36
+ ion-buttons.buttons-collapse {
37
+ filter: blur(2px);
38
+ transform: translateY(8px);
39
+ }
40
+
41
+ ion-content:not(.ios26-disabled)::part(background)::before,
42
+ ion-content:not(.ios26-disabled)::part(background)::after {
43
+ content: '';
44
+ position: absolute;
45
+ width: 100%;
46
+ pointer-events: none;
47
+ z-index: 1;
48
+ }
49
+
50
+ /**
51
+ * ここから下は、ion-content::before/afterが content:'' を持たない限り表示されない
52
+ */
53
+ .ion-page:has(ion-header.header-translucent) > ion-content::part(background)::before {
54
+ z-index: 2;
55
+ top: 0;
56
+ height: calc(68px + max(calc(var(--ion-safe-area-top) - 12px), 4px));
57
+ box-shadow: inset 0 calc(68px + max(calc(var(--ion-safe-area-top) - 12px), 4px)) 16px -16px
58
+ rgba(var(--ios26-color-background-rgb), var(--ios26-content-box-shadow-opacity));
59
+ }
60
+
61
+ ion-content::part(background)::after {
62
+ z-index: 2;
63
+ bottom: 0;
64
+ height: calc(56px + var(--ios26-floating-safe-area-bottom));
65
+ box-shadow: inset 0 calc(-55px - var(--ios26-floating-safe-area-bottom)) 16px -16px
66
+ rgba(var(--ios26-color-background-rgb), var(--ios26-content-box-shadow-opacity));
67
+ }
68
+
69
+ .ion-page:has(ion-footer:not(.footer-translucent)) ion-content::part(background)::after {
70
+ content: none;
71
+ }
package/tsconfig.json ADDED
@@ -0,0 +1,5 @@
1
+ {
2
+ "compilerOptions": {
3
+ "types": ["@ionic/core/dist/types/components"]
4
+ }
5
+ }