base-list-view.ts 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177
  1. import { BaseView } from "./base-view";
  2. import { PouchService } from "../services/pouch-service";
  3. import { Observable } from "rxjs/Observable";
  4. export abstract class BaseListView<T> extends BaseView<T>{
  5. items: T[];
  6. selectedIndex: number;
  7. filters: Array<[string, string, any]>;
  8. constructor(c: { new (): T; }, ...filters: Array<[string, string, any]>) {
  9. super(c, PouchService);
  10. this.items = [];
  11. this.selectedIndex = -1;
  12. this.filters = filters;
  13. this.initialize();
  14. }
  15. /**
  16. *
  17. */
  18. initialize() {
  19. let pouch = super.getInjectable(PouchService);
  20. pouch.getAll(this.getModelName()).subscribe(result => {
  21. this.applyFilter(result.docs);
  22. }, error => {
  23. console.log(error);
  24. });
  25. pouch.changes().subscribe(result => {
  26. console.log("esto es un cambio");
  27. console.log(result);
  28. }, error => console.log(error));
  29. }
  30. /**
  31. *
  32. */
  33. applyFilter(records: T[]): void {
  34. if (records.length == 0) {
  35. return;
  36. }
  37. if (this.getFilters().length == 0) {
  38. this.items = records;
  39. return;
  40. }
  41. this.items = records.filter(record => {
  42. let expressions = this.getFilters().map(filter => {
  43. let operator = "===";
  44. let leftOperand = "record." + filter[0];
  45. let rightOperand = typeof(filter[2]) === "string" ? "'" + filter[2] + "'" : filter[2];
  46. if (filter[1] === "!=") {
  47. operator = "!==";
  48. }
  49. if (filter[1] === ">") {
  50. operator = ">";
  51. }
  52. if (filter[1] === "<") {
  53. operator = "<";
  54. }
  55. if (filter[1] === ">=") {
  56. operator = "<=";
  57. }
  58. if (filter[1] === "<=") {
  59. operator = "<=";
  60. }
  61. return leftOperand + operator + rightOperand;
  62. });
  63. return eval(expressions.join("&&"));
  64. });
  65. }
  66. /**
  67. *
  68. */
  69. performDelete(): Observable<any> {
  70. // return Observable.empty();
  71. return super.getInjectable(PouchService).remove(this.getSelectedItem());
  72. }
  73. /**
  74. *
  75. */
  76. getItems(): T[] {
  77. return this.items;
  78. }
  79. /**
  80. *
  81. * @param items
  82. */
  83. setItems(items: T[]): void {
  84. this.items = items;
  85. this.applyFilter(this.getItems());
  86. }
  87. /**
  88. *
  89. */
  90. getSelectedIndex(): number {
  91. return this.selectedIndex;
  92. }
  93. /**
  94. *
  95. * @param index
  96. */
  97. setSelectedIndex(selectedIndex: number): void {
  98. this.selectedIndex = selectedIndex;
  99. }
  100. /**
  101. *
  102. * @param item
  103. */
  104. indexOf(item: T): number {
  105. return this.getItems().indexOf(item);
  106. }
  107. /**
  108. *
  109. */
  110. getSelectedItem(): T {
  111. if (this.getSelectedIndex() === -1) {
  112. return null;
  113. }
  114. return this.getItems()[this.getSelectedIndex()];
  115. }
  116. /**
  117. *
  118. * @param item
  119. */
  120. setSelectedItem(item: T): void {
  121. let index = this.indexOf(item);
  122. this.setSelectedIndex(index);
  123. }
  124. /**
  125. *
  126. */
  127. deselectItem(): void {
  128. this.setSelectedIndex(-1);
  129. }
  130. /**
  131. *
  132. */
  133. getFilters(): Array<[string, string, any]> {
  134. return this.filters;
  135. }
  136. /**
  137. *
  138. * @param filters
  139. */
  140. setFilters(filters: Array<[string, string, any]>): void {
  141. this.filters = filters;
  142. this.applyFilter(this.getItems());
  143. }
  144. }