@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,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
+ }
@@ -1,10 +1,14 @@
1
1
  :root {
2
+ --ios26-floating-safe-area-top: max(10px, var(--ion-safe-area-top, 0px));
2
3
  --ios26-floating-safe-area-bottom: max(10px, var(--ion-safe-area-bottom, 0px));
3
4
 
5
+ --ios26-content-box-shadow-opacity: 0.8;
6
+
4
7
  --ios26-color-dark-rgb: 0, 0, 0;
5
8
  --ios26-color-light-rgb: 255, 255, 255;
6
9
  --ios26-color-tab-active-rgb: 16, 16, 16;
7
- --ios26-color-shadow-rgb: 224, 224, 224;
10
+ --ios26-color-inner-shadow-rgb: 224, 224, 224;
11
+ --ios26-color-outer-shadow-rgb: 224, 224, 224;
8
12
  --ios26-color-background-rgb: 255, 255, 255;
9
13
  --ios26-color-edge-rgb: 255, 255, 255;
10
14
  }
@@ -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;
@@ -1,4 +1,4 @@
1
- @use 'components-dark/theme-dark';
1
+ @use 'utils/theme-dark';
2
2
 
3
3
  .ion-palette-dark {
4
4
  @include theme-dark.default-variables;
@@ -1,4 +1,4 @@
1
- @use 'components-dark/theme-dark';
1
+ @use 'utils/theme-dark';
2
2
 
3
3
  @media (prefers-color-scheme: dark) {
4
4
  :root {
@@ -1,32 +1,22 @@
1
- @use 'utils/default-variables';
2
-
3
- @use 'utils/api';
4
1
  @use 'utils/translucent';
5
2
 
6
3
  @use 'components/ion-action-sheet';
7
4
  @use 'components/ion-alert';
5
+ @use 'components/ion-breadcrumbs';
8
6
  @use 'components/ion-button';
9
7
  @use 'components/ion-card';
8
+ @use 'components/ion-chip';
9
+ @use 'components/ion-content';
10
+ @use 'components/ion-datetime';
10
11
  @use 'components/ion-fab';
11
12
  @use 'components/ion-list';
13
+ @use 'components/ion-loading';
12
14
  @use 'components/ion-modal';
15
+ @use 'components/ion-picker';
13
16
  @use 'components/ion-popover';
17
+ @use 'components/ion-range';
14
18
  @use 'components/ion-searchbar';
15
- @use 'components/ion-segment';
16
19
  @use 'components/ion-tabs';
17
20
  @use 'components/ion-toast';
18
21
  @use 'components/ion-toggle';
19
-
20
- .ios {
21
- /**
22
- * iOS26から上下のセーフエリアいっぱいまでコンテンツを表示するようになったため、
23
- * コンテンツのmarginとpaddingを調整します。なお、Angular CDK Scrollingにも対応しています。
24
- */
25
- .ion-page:not(:has(ion-footer)) cdk-virtual-scroll-viewport {
26
- margin-bottom: calc(calc(56px + var(--ios26-floating-safe-area-bottom)) * -1);
27
- padding-bottom: calc(56px + var(--ios26-floating-safe-area-bottom));
28
- }
29
- ion-content:not(:has(cdk-virtual-scroll-viewport)) {
30
- --padding-bottom: calc(56px + var(--ios26-floating-safe-area-bottom));
31
- }
32
- }
22
+ @use 'components/ion-toolbar';
@@ -1,20 +1,21 @@
1
- @mixin glass-background($opacity: 0.4, $blur: 6px, $saturate: 180%) {
1
+ @mixin glass-background($opacity: 0.7, $blur: 2px, $saturate: 360%) {
2
2
  background: rgba(var(--ios26-color-light-rgb), $opacity);
3
3
  backdrop-filter: blur($blur) saturate($saturate);
4
4
  box-shadow:
5
- inset 0 0 8px 0 rgba(var(--ios26-color-shadow-rgb), 0.2),
6
- 0 0 12px 0 rgba(var(--ios26-color-shadow-rgb), 0.8);
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
7
  border-top: 0.5px solid rgba(var(--ios26-color-edge-rgb), 1);
8
8
  border-right: 0.5px solid rgba(var(--ios26-color-edge-rgb), 0.8);
9
9
  border-bottom: 0.5px solid rgba(var(--ios26-color-edge-rgb), 1);
10
10
  border-left: 0.5px solid rgba(var(--ios26-color-edge-rgb), 0.6);
11
- transition: box-shadow 0.1s ease;
12
11
  }
13
12
 
14
- @mixin glass-background-dark-active($opacity: 0.25, $blur: 7px, $saturate: 180%) {
13
+ @mixin glass-background-dark-active($opacity: 0.4, $blur: 7px, $saturate: 180%) {
15
14
  background: rgba(var(--ios26-color-tab-active-rgb), $opacity);
16
15
  backdrop-filter: blur($blur) saturate($saturate);
17
- box-shadow: inset 0 0 8px 0 rgba(var(--ios26-color-tab-active-rgb), 0.2);
18
- border: 0.5px solid rgba(var(--ios26-color-tab-active-rgb), 0.7);
19
- transition: box-shadow 0.1s ease;
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);
20
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
+ }
@@ -1,14 +1,16 @@
1
- @use '../components-dark/ion-button';
1
+ @forward 'dark/ion-button';
2
+ @use 'dark/ion-button' as *;
2
3
 
3
4
  @mixin default-variables {
4
5
  --ios26-color-dark-rgb: 255, 255, 255;
5
6
  --ios26-color-light-rgb: 58, 58, 58;
6
7
  --ios26-color-tab-active-rgb: 255, 255, 255;
7
- --ios26-color-shadow-rgb: translarent;
8
+ --ios26-color-inner-shadow-rgb: translarent;
9
+ --ios26-color-outer-shadow-rgb: translarent;
8
10
  --ios26-color-background-rgb: 0, 0, 0;
9
11
  --ios26-color-edge-rgb: 64, 64, 64;
10
12
  }
11
13
 
12
14
  @mixin theme-dark {
13
- @include ion-button.ion-button-dark;
15
+ @include ion-button;
14
16
  }
@@ -55,30 +55,35 @@
55
55
  }
56
56
  }
57
57
 
58
- ion-item-group ion-item {
59
- ion-text[slot='end'] {
60
- padding-left: 8px;
61
- }
58
+ ion-item-group,
59
+ ion-reorder-group,
60
+ ion-accordion-group,
61
+ ion-radio-group {
62
+ ion-item {
63
+ ion-text[slot='end'] {
64
+ padding-left: 8px;
65
+ }
62
66
 
63
- &.item-disabled {
64
- opacity: 1;
67
+ &.item-disabled {
68
+ opacity: 1;
65
69
 
66
- & > * {
67
- opacity: 0.4;
68
- }
70
+ & > * {
71
+ opacity: 0.4;
72
+ }
69
73
 
70
- &::part(detail-icon) {
71
- opacity: 0.1;
74
+ &::part(detail-icon) {
75
+ opacity: 0.1;
76
+ }
72
77
  }
73
- }
74
78
 
75
- ion-button[slot='end'] {
76
- &.ion-align-self-end {
77
- transform: translateY(-7px);
78
- }
79
- ion-icon[slot='icon-only'] {
80
- font-size: 1.2rem !important;
81
- transform: translateY(4px);
79
+ ion-button[slot='end'] {
80
+ &.ion-align-self-end {
81
+ transform: translateY(-7px);
82
+ }
83
+ ion-icon[slot='icon-only'] {
84
+ font-size: 1.2rem !important;
85
+ transform: translateY(4px);
86
+ }
82
87
  }
83
88
  }
84
89
  }
@@ -1,70 +1,71 @@
1
1
  @use 'api';
2
2
 
3
- .ios {
4
- ion-header.header-translucent,
5
- ion-footer.footer-translucent {
6
- .header-background,
7
- .footer-background {
8
- backdrop-filter: none;
9
- }
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
+ }
10
9
 
11
- ion-toolbar {
12
- --border-width: 0;
13
- --background: transparent;
14
- /**
15
- * TODO: Not expect work.
16
- * https://github.com/ionic-team/ionic-framework/blob/3b80473f2fd5ad4da5a9f5d66f783a69909c8965/core/src/utils/transition/ios.transition.ts#L829C51-L829C60
17
- * --opacity: 0;
18
- */
19
- .toolbar-background {
20
- background: transparent !important;
21
- }
22
- ion-title {
23
- filter: blur(0);
24
- transform: translateY(0);
25
- }
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);
26
24
  }
27
25
  }
26
+ }
28
27
 
29
- .header-collapse-main ion-toolbar.in-toolbar ion-title,
30
- .header-collapse-main ion-toolbar.in-toolbar ion-buttons {
31
- transition: all 0.5s ease-in-out;
32
- }
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
+ }
33
32
 
34
- .header-collapse-condense-inactive:not(.header-collapse-condense) ion-toolbar.in-toolbar ion-title,
35
- .header-collapse-condense-inactive:not(.header-collapse-condense) ion-toolbar.in-toolbar ion-buttons.buttons-collapse {
36
- filter: blur(2px);
37
- transform: translateY(8px);
38
- }
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
+ }
39
40
 
40
- ion-content::part(background)::before,
41
- ion-content::part(background)::after {
42
- content: '';
43
- position: absolute;
44
- width: 100%;
45
- pointer-events: none;
46
- z-index: 1;
47
- }
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
+ }
48
49
 
49
- .ion-page:has(ion-header.header-translucent) ion-content::part(background)::before {
50
- z-index: 2;
51
- top: 0;
52
- height: calc(66px + var(--ion-safe-area-top));
53
- box-shadow:
54
- inset 0 0 0 0 rgba(var(--ios26-color-background-rgb), 0),
55
- inset 0 calc(66px + var(--ion-safe-area-top)) 20px -20px rgba(var(--ios26-color-background-rgb), 1);
56
- }
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
+ }
57
60
 
58
- ion-content::part(background)::after {
59
- z-index: 2;
60
- bottom: 0;
61
- height: calc(56px + var(--ios26-floating-safe-area-bottom));
62
- box-shadow:
63
- inset 0 0 0 0 rgba(var(--ios26-color-background-rgb), 0),
64
- inset 0 calc(-50px - var(--ios26-floating-safe-area-bottom)) 40px -40px rgba(var(--ios26-color-background-rgb), 0.8);
65
- }
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
+ }
66
68
 
67
- .ion-page:has(ion-footer:not(.footer-translucent)) ion-content::part(background)::after {
68
- content: none;
69
- }
69
+ .ion-page:has(ion-footer:not(.footer-translucent)) ion-content::part(background)::after {
70
+ content: none;
70
71
  }
package/build-sass.js DELETED
@@ -1,25 +0,0 @@
1
- const { execSync } = require('child_process');
2
- const fs = require('fs');
3
- const path = require('path');
4
-
5
- const srcDir = path.resolve(__dirname, 'src');
6
- const outDir = path.resolve(__dirname, 'dist/css');
7
-
8
- // 出力先ディレクトリがなければ作る
9
- if (!fs.existsSync(outDir)) {
10
- fs.mkdirSync(outDir, { recursive: true });
11
- }
12
-
13
- // src ディレクトリの .scss ファイルを取得
14
- const scssFiles = fs.readdirSync(srcDir).filter(f => f.endsWith('.scss'));
15
-
16
- scssFiles.forEach(file => {
17
- const srcPath = path.join(srcDir, file);
18
- const fileName = path.basename(file, '.scss');
19
- const outPath = path.join(outDir, `${fileName}.min.css`);
20
-
21
- console.log(`Building ${srcPath} → ${outPath}`);
22
- execSync(`npx sass ${srcPath} ${outPath} --style=compressed`, { stdio: 'inherit' });
23
- });
24
-
25
- console.log('All SCSS files compiled successfully!');
@@ -1,25 +0,0 @@
1
- /**
2
- * You should use:
3
- * @use '@rdlabo/ionic-theme-ios26/dist/css/ionic-theme-ios26.min.css';
4
- * Here for development:
5
- */
6
- @use '../../../src/ionic-theme-ios26';
7
-
8
- :root {
9
- --ios26-color-background-rgb: var(--ion-color-light-rgb);
10
- }
11
-
12
- ion-back-button {
13
- --color: var(--ion-color-dark);
14
- }
15
-
16
- section.section-example {
17
- background: var(--ion-background-color, #fff);
18
- border-radius: 24px;
19
- padding: 16px;
20
- margin: 16px;
21
- }
22
-
23
- ion-searchbar .searchbar-input-container {
24
- margin: 0 20px !important;
25
- }
@@ -1,28 +0,0 @@
1
- @use '../utils/api';
2
-
3
- @mixin theme-dark-button {
4
- &.ion-activated {
5
- &::part(native) {
6
- @include api.glass-background-dark-active;
7
- }
8
- ion-icon {
9
- color: rgb(255, 255, 255) !important;
10
- }
11
- }
12
- }
13
-
14
- @mixin ion-button-dark {
15
- ion-header.ios,
16
- ion-footer.ios {
17
- ion-buttons:not(.ios26-no-liquid-glass) ion-button:not(.ios26-no-liquid-glass),
18
- ion-buttons:not(.ios26-no-liquid-glass) ion-back-button:not(.ios26-no-liquid-glass) {
19
- @include theme-dark-button;
20
- }
21
- }
22
-
23
- ion-buttons.ios.ios26-liquid-glass ion-button:not(.ios26-no-liquid-glass),
24
- ion-buttons.ios.ios26-liquid-glass ion-back-button:not(.ios26-no-liquid-glass),
25
- ion-button.ios.ios26-liquid-glass {
26
- @include theme-dark-button;
27
- }
28
- }