@rdlabo/ionic-theme-ios26 0.0.3 → 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 (141) 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 +9 -1
  13. package/demo/src/app/index/index-page.component.spec.ts +6 -6
  14. package/demo/src/app/index/index-page.component.ts +24 -26
  15. package/demo/src/app/index/index.routes.ts +64 -0
  16. package/demo/src/app/index/pages/action-sheet/action-sheet.page.spec.ts +5 -1
  17. package/demo/src/app/index/pages/action-sheet/action-sheet.page.ts +3 -5
  18. package/demo/src/app/index/pages/alert/alert.page.spec.ts +5 -1
  19. package/demo/src/app/index/pages/alert/alert.page.ts +0 -2
  20. package/demo/src/app/index/pages/breadcrumbs/breadcrumbs.page.html +41 -0
  21. package/demo/src/app/index/pages/breadcrumbs/breadcrumbs.page.scss +0 -0
  22. package/demo/src/app/index/pages/breadcrumbs/breadcrumbs.page.spec.ts +21 -0
  23. package/demo/src/app/index/pages/breadcrumbs/breadcrumbs.page.ts +47 -0
  24. package/demo/src/app/index/pages/button/button.page.html +41 -19
  25. package/demo/src/app/index/pages/button/button.page.scss +3 -0
  26. package/demo/src/app/index/pages/button/button.page.spec.ts +5 -1
  27. package/demo/src/app/index/pages/button/button.page.ts +0 -2
  28. package/demo/src/app/index/pages/card/card.page.html +171 -0
  29. package/demo/src/app/index/pages/card/card.page.scss +0 -0
  30. package/demo/src/app/index/pages/card/card.page.spec.ts +21 -0
  31. package/demo/src/app/index/pages/card/card.page.ts +57 -0
  32. package/demo/src/app/index/pages/checkbox/checkbox.page.spec.ts +5 -1
  33. package/demo/src/app/index/pages/checkbox/checkbox.page.ts +0 -2
  34. package/demo/src/app/index/pages/chip/chip.page.html +72 -0
  35. package/demo/src/app/index/pages/chip/chip.page.scss +0 -0
  36. package/demo/src/app/index/pages/chip/chip.page.spec.ts +21 -0
  37. package/demo/src/app/index/pages/chip/chip.page.ts +47 -0
  38. package/demo/src/app/index/pages/date-and-time-pickers/date-and-time-pickers.page.html +48 -0
  39. package/demo/src/app/index/pages/date-and-time-pickers/date-and-time-pickers.page.scss +0 -0
  40. package/demo/src/app/index/pages/date-and-time-pickers/date-and-time-pickers.page.spec.ts +21 -0
  41. package/demo/src/app/index/pages/date-and-time-pickers/date-and-time-pickers.page.ts +55 -0
  42. package/demo/src/app/index/pages/floating-action-button/floating-action-button.page.html +106 -0
  43. package/demo/src/app/index/pages/floating-action-button/floating-action-button.page.scss +0 -0
  44. package/demo/src/app/index/pages/floating-action-button/floating-action-button.page.spec.ts +21 -0
  45. package/demo/src/app/index/pages/floating-action-button/floating-action-button.page.ts +49 -0
  46. package/demo/src/app/index/pages/menu/menu.page.html +13 -0
  47. package/demo/src/app/index/pages/menu/menu.page.scss +0 -0
  48. package/demo/src/app/index/pages/menu/menu.page.spec.ts +21 -0
  49. package/demo/src/app/index/pages/menu/menu.page.ts +17 -0
  50. package/demo/src/app/index/pages/modal/modal.page.html +37 -0
  51. package/demo/src/app/index/pages/modal/modal.page.scss +0 -0
  52. package/demo/src/app/index/pages/modal/modal.page.spec.ts +21 -0
  53. package/demo/src/app/index/pages/modal/modal.page.ts +77 -0
  54. package/demo/src/app/index/pages/popover/popover.page.html +34 -0
  55. package/demo/src/app/index/pages/popover/popover.page.scss +0 -0
  56. package/demo/src/app/index/pages/popover/popover.page.spec.ts +21 -0
  57. package/demo/src/app/index/pages/popover/popover.page.ts +47 -0
  58. package/demo/src/app/index/pages/progress-indicators/progress-indicators.page.html +28 -0
  59. package/demo/src/app/index/pages/progress-indicators/progress-indicators.page.scss +0 -0
  60. package/demo/src/app/index/pages/progress-indicators/progress-indicators.page.spec.ts +21 -0
  61. package/demo/src/app/index/pages/progress-indicators/progress-indicators.page.ts +47 -0
  62. package/demo/src/app/index/pages/radio/radio.page.html +39 -0
  63. package/demo/src/app/index/pages/radio/radio.page.scss +0 -0
  64. package/demo/src/app/index/pages/radio/radio.page.spec.ts +21 -0
  65. package/demo/src/app/index/pages/radio/radio.page.ts +47 -0
  66. package/demo/src/app/index/pages/range/range.page.html +58 -0
  67. package/demo/src/app/index/pages/range/range.page.scss +0 -0
  68. package/demo/src/app/index/pages/range/range.page.spec.ts +21 -0
  69. package/demo/src/app/index/pages/range/range.page.ts +49 -0
  70. package/demo/src/app/index/pages/searchbar/searchbar.page.html +33 -0
  71. package/demo/src/app/index/pages/searchbar/searchbar.page.scss +0 -0
  72. package/demo/src/app/index/pages/searchbar/searchbar.page.spec.ts +21 -0
  73. package/demo/src/app/index/pages/searchbar/searchbar.page.ts +45 -0
  74. package/demo/src/app/index/pages/segment/segment.page.html +102 -0
  75. package/demo/src/app/index/pages/segment/segment.page.scss +0 -0
  76. package/demo/src/app/index/pages/segment/segment.page.spec.ts +21 -0
  77. package/demo/src/app/index/pages/segment/segment.page.ts +51 -0
  78. package/demo/src/app/index/pages/select/select.page.html +74 -0
  79. package/demo/src/app/index/pages/select/select.page.scss +0 -0
  80. package/demo/src/app/index/pages/select/select.page.spec.ts +21 -0
  81. package/demo/src/app/index/pages/select/select.page.ts +50 -0
  82. package/demo/src/app/index/pages/toast/toast.page.html +32 -0
  83. package/demo/src/app/index/pages/toast/toast.page.scss +0 -0
  84. package/demo/src/app/index/pages/toast/toast.page.spec.ts +21 -0
  85. package/demo/src/app/index/pages/toast/toast.page.ts +66 -0
  86. package/demo/src/app/index/pages/toggle/toggle.page.html +45 -0
  87. package/demo/src/app/index/pages/toggle/toggle.page.scss +0 -0
  88. package/demo/src/app/index/pages/toggle/toggle.page.spec.ts +21 -0
  89. package/demo/src/app/index/pages/toggle/toggle.page.ts +49 -0
  90. package/demo/src/app/settings/settings-page.component.html +4 -7
  91. package/demo/src/app/settings/settings-page.component.spec.ts +2 -2
  92. package/demo/src/app/tabs/tabs.page.html +4 -4
  93. package/demo/src/app/tabs/tabs.page.spec.ts +1 -1
  94. package/demo/src/app/tabs/tabs.routes.ts +0 -1
  95. package/demo/src/global.scss +28 -10
  96. package/demo/src/index.html +1 -1
  97. package/demo/src/test.ts +7 -0
  98. package/demo/src/theme/variables.scss +18 -0
  99. package/demo/util/mocks/angular/angular-delegate.ts +18 -0
  100. package/demo/util/mocks/angular/ion-router-outlet.ts +39 -0
  101. package/demo/util/mocks/angular/modal-controller.ts +7 -0
  102. package/demo/util/mocks/angular/nav-controller.ts +22 -0
  103. package/demo/util/mocks/angular/popover-controller.ts +7 -0
  104. package/demo/util/mocks/util/base.mock.ts +13 -0
  105. package/demo/util/mocks/util/overlay.ts +13 -0
  106. package/demo/util/test.config.ts +54 -0
  107. package/package.json +3 -2
  108. package/src/components/ion-action-sheet.scss +23 -4
  109. package/src/components/ion-alert.scss +17 -2
  110. package/src/components/ion-breadcrumbs.scss +24 -0
  111. package/src/components/ion-button.scss +105 -62
  112. package/src/components/ion-card.scss +5 -1
  113. package/src/components/ion-chip.scss +10 -0
  114. package/src/components/ion-content.scss +13 -0
  115. package/src/components/ion-datetime.scss +9 -0
  116. package/src/components/ion-fab.scss +10 -4
  117. package/src/components/ion-list.scss +7 -2
  118. package/src/components/ion-loading.scss +9 -0
  119. package/src/components/ion-modal.scss +26 -1
  120. package/src/components/ion-picker.scss +4 -0
  121. package/src/components/ion-popover.scss +8 -16
  122. package/src/components/ion-range.scss +21 -0
  123. package/src/components/ion-searchbar.scss +2 -2
  124. package/src/components/ion-segment.scss +40 -5
  125. package/src/components/ion-tabs.scss +2 -2
  126. package/src/components/ion-toast.scss +11 -2
  127. package/src/components/ion-toggle.scss +37 -28
  128. package/src/components/ion-toolbar.scss +27 -0
  129. package/src/{utils/default-variables.scss → default-variables.scss} +3 -1
  130. package/src/ionic-theme-ios26-dark-always.scss +6 -0
  131. package/src/{ionic-theme-dark-class.scss → ionic-theme-ios26-dark-class.scss} +1 -1
  132. package/src/{ionic-theme-dark-system.scss → ionic-theme-ios26-dark-system.scss} +1 -1
  133. package/src/ionic-theme-ios26.scss +8 -17
  134. package/src/utils/api.scss +9 -8
  135. package/src/utils/dark/ion-button.scss +45 -0
  136. package/src/{components-dark → utils}/theme-dark.scss +5 -3
  137. package/src/utils/theme-list-inset.scss +23 -19
  138. package/src/utils/translucent.scss +59 -58
  139. package/build-sass.js +0 -25
  140. package/demo/src/theme/theme-ios26.scss +0 -25
  141. package/src/components-dark/ion-button.scss +0 -28
@@ -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,6 +1,6 @@
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
 
@@ -34,7 +34,7 @@ ion-tab-bar.ios {
34
34
  &.tab-selected {
35
35
  &::part(native) {
36
36
  backdrop-filter: blur(7px);
37
- background: rgba(var(--ios26-color-tab-active-rgb), 0.1);
37
+ background: rgba(var(--ios26-color-tab-active-rgb), 0.095);
38
38
  transition: background 0.2s ease;
39
39
  border-radius: 32px;
40
40
  }
@@ -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
  }
@@ -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,12 @@
1
1
  :root {
2
2
  --ios26-floating-safe-area-bottom: max(10px, var(--ion-safe-area-bottom, 0px));
3
+ --ios26-content-box-shadow-opacity: 0.8;
3
4
 
4
5
  --ios26-color-dark-rgb: 0, 0, 0;
5
6
  --ios26-color-light-rgb: 255, 255, 255;
6
7
  --ios26-color-tab-active-rgb: 16, 16, 16;
7
- --ios26-color-shadow-rgb: 224, 224, 224;
8
+ --ios26-color-inner-shadow-rgb: 224, 224, 224;
9
+ --ios26-color-outer-shadow-rgb: 224, 224, 224;
8
10
  --ios26-color-background-rgb: 255, 255, 255;
9
11
  --ios26-color-edge-rgb: 255, 255, 255;
10
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;
@@ -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,23 @@
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
19
  @use 'components/ion-segment';
16
20
  @use 'components/ion-tabs';
17
21
  @use 'components/ion-toast';
18
22
  @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
- }
23
+ @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,34 @@
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-radio-group {
61
+ ion-item {
62
+ ion-text[slot='end'] {
63
+ padding-left: 8px;
64
+ }
62
65
 
63
- &.item-disabled {
64
- opacity: 1;
66
+ &.item-disabled {
67
+ opacity: 1;
65
68
 
66
- & > * {
67
- opacity: 0.4;
68
- }
69
+ & > * {
70
+ opacity: 0.4;
71
+ }
69
72
 
70
- &::part(detail-icon) {
71
- opacity: 0.1;
73
+ &::part(detail-icon) {
74
+ opacity: 0.1;
75
+ }
72
76
  }
73
- }
74
77
 
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);
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
+ }
82
86
  }
83
87
  }
84
88
  }
@@ -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!');