@nubitio/react-admin 0.5.26 → 0.5.27

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 (2) hide show
  1. package/dist/style.css +138 -19
  2. package/package.json +7 -7
package/dist/style.css CHANGED
@@ -3655,10 +3655,10 @@ html[data-density=compact] .nb-drawer__footer {
3655
3655
  outline: 0;
3656
3656
  transition: background var(--transition-fast), box-shadow var(--transition-fast);
3657
3657
  }
3658
- .nb-datagrid--zebra .nb-datagrid__row:nth-child(even) td {
3658
+ .nb-datagrid--zebra .nb-datagrid__row:nth-child(even) td:not(.nb-datagrid__cell--dirty):not(.nb-datagrid__cell--active) {
3659
3659
  background: var(--grid-row-alt-bg);
3660
3660
  }
3661
- .nb-datagrid__row:hover td {
3661
+ .nb-datagrid__row:hover td:not(.nb-datagrid__cell--dirty):not(.nb-datagrid__cell--active):not(.nb-datagrid__edit-cell) {
3662
3662
  background: var(--grid-row-hover-bg, var(--surface-2));
3663
3663
  }
3664
3664
  .nb-datagrid__row:focus-visible {
@@ -4953,10 +4953,11 @@ html[data-density=compact] .nb-datagrid .nb-badge {
4953
4953
  }
4954
4954
  }
4955
4955
  .nb-datagrid__row--editing {
4956
- background: color-mix(in srgb, var(--accent) 6%, var(--surface-0));
4956
+ background: color-mix(in srgb, var(--accent-color, var(--accent)) 5%, var(--surface-0));
4957
4957
  }
4958
- .nb-datagrid__row--editing td {
4959
- cursor: default;
4958
+
4959
+ .nb-datagrid__row--dirty .nb-datagrid__cell--dirty {
4960
+ background: color-mix(in srgb, #4caf50 34%, var(--surface-1, #fff));
4960
4961
  }
4961
4962
 
4962
4963
  .nb-datagrid__row--saving {
@@ -4964,42 +4965,142 @@ html[data-density=compact] .nb-datagrid .nb-badge {
4964
4965
  pointer-events: none;
4965
4966
  }
4966
4967
 
4968
+ .nb-datagrid__data-cell {
4969
+ cursor: default;
4970
+ }
4971
+
4972
+ .nb-datagrid__cell--editable {
4973
+ cursor: cell;
4974
+ }
4975
+ .nb-datagrid__cell--editable:hover:not(.nb-datagrid__cell--dirty):not(.nb-datagrid__cell--active) {
4976
+ background: color-mix(in srgb, var(--accent) 4%, var(--surface-0));
4977
+ }
4978
+
4979
+ .nb-datagrid__table td.nb-datagrid__cell--dirty {
4980
+ background: color-mix(in srgb, #4caf50 34%, var(--surface-1, #fff));
4981
+ box-shadow: inset 0 0 0 1px color-mix(in srgb, #4caf50 72%, transparent);
4982
+ }
4983
+
4984
+ .nb-datagrid--zebra .nb-datagrid__row:nth-child(even) td.nb-datagrid__cell--dirty,
4985
+ .nb-datagrid__row:hover td.nb-datagrid__cell--dirty,
4986
+ .nb-datagrid__row--selected td.nb-datagrid__cell--dirty {
4987
+ background: color-mix(in srgb, #4caf50 34%, var(--surface-1, #fff));
4988
+ box-shadow: inset 0 0 0 1px color-mix(in srgb, #4caf50 72%, transparent);
4989
+ }
4990
+
4991
+ .nb-datagrid__table td.nb-datagrid__cell--active {
4992
+ background: color-mix(in srgb, #4caf50 42%, var(--surface-1, #fff));
4993
+ box-shadow: inset 0 0 0 2px color-mix(in srgb, #4caf50 78%, transparent);
4994
+ }
4995
+
4996
+ .nb-datagrid--zebra .nb-datagrid__row:nth-child(even) td.nb-datagrid__cell--active,
4997
+ .nb-datagrid__row:hover td.nb-datagrid__cell--active,
4998
+ .nb-datagrid__row--selected td.nb-datagrid__cell--active {
4999
+ background: color-mix(in srgb, #4caf50 42%, var(--surface-1, #fff));
5000
+ box-shadow: inset 0 0 0 2px color-mix(in srgb, #4caf50 78%, transparent);
5001
+ }
5002
+
4967
5003
  .nb-datagrid__edit-cell {
4968
- padding: 3px 4px;
5004
+ padding: 2px 4px;
4969
5005
  vertical-align: middle;
4970
5006
  }
4971
5007
 
4972
5008
  .nb-inline-cell {
4973
5009
  width: 100%;
5010
+ min-width: 0;
4974
5011
  }
4975
5012
  .nb-inline-cell .nb-inline-control,
4976
5013
  .nb-inline-cell .nb-inline-control input,
4977
5014
  .nb-inline-cell .nb-inline-control select,
4978
- .nb-inline-cell .nb-inline-control textarea {
5015
+ .nb-inline-cell .nb-inline-control textarea,
5016
+ .nb-inline-cell .nb-form__control,
5017
+ .nb-inline-cell .nb-form__control input,
5018
+ .nb-inline-cell .nb-form__control select,
5019
+ .nb-inline-cell .nb-form__control textarea {
4979
5020
  font-size: 13px;
4980
- height: 30px;
4981
- min-height: 30px;
4982
- padding: 0 6px;
5021
+ line-height: 1.3;
5022
+ height: 28px;
5023
+ min-height: 28px;
5024
+ padding: 0 8px;
5025
+ border: 1px solid color-mix(in srgb, var(--border-color) 85%, var(--accent));
4983
5026
  border-radius: var(--radius-sm);
4984
5027
  box-sizing: border-box;
4985
5028
  width: 100%;
5029
+ background: var(--surface-0);
5030
+ color: var(--text-primary);
5031
+ box-shadow: none;
5032
+ transition: border-color 0.12s, box-shadow 0.12s;
5033
+ }
5034
+ .nb-inline-cell .nb-inline-control:focus,
5035
+ .nb-inline-cell .nb-inline-control input:focus,
5036
+ .nb-inline-cell .nb-inline-control select:focus,
5037
+ .nb-inline-cell .nb-inline-control textarea:focus,
5038
+ .nb-inline-cell .nb-form__control:focus,
5039
+ .nb-inline-cell .nb-form__control input:focus,
5040
+ .nb-inline-cell .nb-form__control select:focus,
5041
+ .nb-inline-cell .nb-form__control textarea:focus {
5042
+ outline: none;
5043
+ border-color: var(--accent);
5044
+ box-shadow: 0 0 0 2px color-mix(in srgb, var(--accent) 22%, transparent);
4986
5045
  }
4987
- .nb-inline-cell .nb-inline-control textarea {
4988
- height: 56px;
4989
- padding: 4px 6px;
4990
- resize: none;
5046
+ .nb-datagrid__cell--dirty .nb-inline-cell .nb-inline-control:focus, .nb-datagrid__cell--active .nb-inline-cell .nb-inline-control:focus, .nb-datagrid__cell--dirty .nb-inline-cell .nb-form__control:focus, .nb-datagrid__cell--active .nb-inline-cell .nb-form__control:focus {
5047
+ border-color: color-mix(in srgb, #4caf50 70%, var(--accent-color, var(--accent)));
5048
+ box-shadow: 0 0 0 2px color-mix(in srgb, #4caf50 28%, transparent);
5049
+ }
5050
+ .nb-inline-cell .nb-inline-control textarea,
5051
+ .nb-inline-cell .nb-form__control textarea {
5052
+ height: 52px;
5053
+ padding: 4px 8px;
5054
+ resize: vertical;
4991
5055
  }
4992
5056
  .nb-inline-cell .nb-form-switch,
4993
5057
  .nb-inline-cell .nb-form-checkbox {
4994
5058
  margin: 0;
4995
5059
  }
4996
- .nb-inline-cell .nb-lookup__trigger {
4997
- height: 30px;
5060
+ .nb-inline-cell .nb-dropdown {
5061
+ width: 100%;
5062
+ }
5063
+ .nb-inline-cell .nb-dropdown__trigger {
5064
+ height: 28px;
5065
+ min-height: 28px;
5066
+ font-size: 13px;
5067
+ padding: 0 8px;
5068
+ border-radius: var(--radius-sm);
5069
+ }
5070
+ .nb-inline-cell .nb-date-picker {
5071
+ width: 100%;
5072
+ }
5073
+ .nb-inline-cell .nb-date-picker__trigger {
5074
+ height: 28px;
5075
+ min-height: 28px;
5076
+ border-radius: var(--radius-sm);
5077
+ border: 1px solid color-mix(in srgb, var(--border-color) 85%, var(--accent));
5078
+ background: var(--surface-0);
5079
+ }
5080
+ .nb-inline-cell .nb-date-picker__input {
5081
+ font-size: 13px;
5082
+ padding: 0 4px;
5083
+ }
5084
+ .nb-inline-cell .nb-form__lookup {
5085
+ width: 100%;
5086
+ }
5087
+ .nb-inline-cell .nb-form__lookup .nb-form__control,
5088
+ .nb-inline-cell .nb-form__lookup.has-value .nb-form__control {
5089
+ height: 28px;
5090
+ min-height: 28px;
4998
5091
  font-size: 13px;
5092
+ padding-right: 52px;
5093
+ }
5094
+ .nb-inline-cell .nb-form__lookup-toggle,
5095
+ .nb-inline-cell .nb-form__lookup-clear {
5096
+ width: 24px;
5097
+ height: 24px;
4999
5098
  }
5000
5099
  .nb-inline-cell.nb-inline-cell--error .nb-inline-control,
5001
5100
  .nb-inline-cell.nb-inline-cell--error .nb-inline-control input,
5002
- .nb-inline-cell.nb-inline-cell--error .nb-inline-control select {
5101
+ .nb-inline-cell.nb-inline-cell--error .nb-inline-control select,
5102
+ .nb-inline-cell.nb-inline-cell--error .nb-form__control,
5103
+ .nb-inline-cell.nb-inline-cell--error .nb-date-picker__trigger {
5003
5104
  border-color: var(--color-danger);
5004
5105
  }
5005
5106
 
@@ -5043,15 +5144,33 @@ html[data-density=compact] .nb-datagrid .nb-badge {
5043
5144
  color: var(--text-primary);
5044
5145
  }
5045
5146
 
5147
+ .nb-datagrid__toolbar-icon-action--save {
5148
+ color: var(--accent);
5149
+ }
5150
+ .nb-datagrid__toolbar-icon-action--save:hover {
5151
+ background: color-mix(in srgb, var(--accent) 12%, transparent);
5152
+ }
5153
+
5154
+ .nb-datagrid__toolbar-icon-action--revert {
5155
+ color: var(--text-secondary);
5156
+ }
5157
+ .nb-datagrid__toolbar-icon-action--revert:hover {
5158
+ background: var(--surface-2);
5159
+ color: var(--text-primary);
5160
+ }
5161
+
5046
5162
  .nb-datagrid__batch-bar {
5047
5163
  display: flex;
5048
5164
  align-items: center;
5049
5165
  gap: var(--space-3);
5050
5166
  padding: 8px 14px;
5051
- background: color-mix(in srgb, var(--accent) 10%, var(--surface-0));
5052
- border-bottom: 1px solid color-mix(in srgb, var(--accent) 30%, transparent);
5167
+ background: color-mix(in srgb, #4caf50 10%, var(--surface-0));
5168
+ border-bottom: 1px solid color-mix(in srgb, #4caf50 24%, transparent);
5053
5169
  font-size: 13px;
5054
5170
  }
5171
+ .nb-datagrid__batch-bar--compact {
5172
+ padding-block: 6px;
5173
+ }
5055
5174
 
5056
5175
  .nb-datagrid__batch-bar-label {
5057
5176
  flex: 1;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@nubitio/react-admin",
3
- "version": "0.5.26",
3
+ "version": "0.5.27",
4
4
  "type": "module",
5
5
  "description": "Batteries-included admin stack: core runtime, CRUD, Hydra adapter, and AdminShell.",
6
6
  "license": "MIT",
@@ -50,12 +50,12 @@
50
50
  "access": "public"
51
51
  },
52
52
  "dependencies": {
53
- "@nubitio/admin": "^0.5.26",
54
- "@nubitio/core": "^0.5.26",
55
- "@nubitio/hydra": "^0.5.26",
56
- "@nubitio/crud": "^0.5.26",
57
- "@nubitio/dashboard": "^0.5.26",
58
- "@nubitio/ui": "^0.5.26"
53
+ "@nubitio/admin": "^0.5.27",
54
+ "@nubitio/core": "^0.5.27",
55
+ "@nubitio/crud": "^0.5.27",
56
+ "@nubitio/ui": "^0.5.27",
57
+ "@nubitio/hydra": "^0.5.27",
58
+ "@nubitio/dashboard": "^0.5.27"
59
59
  },
60
60
  "peerDependencies": {
61
61
  "@tanstack/react-query": "^5.0.0",