deleted_at) { return $model->name; } elseif ($model->gateway_id == GATEWAY_CUSTOM) { $accountGateway = $this->getAccountGateway($model->id); $name = $accountGateway->getConfigField('name') . ' [' . trans('texts.custom') . ']'; return link_to("gateways/{$model->public_id}/edit", $name)->toHtml(); } elseif ($model->gateway_id != GATEWAY_WEPAY) { return link_to("gateways/{$model->public_id}/edit", $model->name)->toHtml(); } else { $accountGateway = $this->getAccountGateway($model->id); $config = $accountGateway->getConfig(); $endpoint = WEPAY_ENVIRONMENT == WEPAY_STAGE ? 'https://stage.wepay.com/' : 'https://www.wepay.com/'; $wepayAccountId = $config->accountId; $wepayState = isset($config->state)?$config->state:null; $linkText = $model->name; $url = $endpoint.'account/'.$wepayAccountId; $html = link_to($url, $linkText, ['target'=>'_blank'])->toHtml(); try { if ($wepayState == 'action_required') { $updateUri = $endpoint.'api/account_update/'.$wepayAccountId.'?redirect_uri='.urlencode(URL::to('gateways')); $linkText .= ' ('.trans('texts.action_required').')'; $url = $updateUri; $html = "{$linkText}"; $model->setupUrl = $url; } elseif ($wepayState == 'pending') { $linkText .= ' ('.trans('texts.resend_confirmation_email').')'; $model->resendConfirmationUrl = $url = URL::to("gateways/{$accountGateway->public_id}/resend_confirmation"); $html = link_to($url, $linkText)->toHtml(); } } catch(\WePayException $ex){} return $html; } } ], [ 'limit', function ($model) { if ($model->gateway_id == GATEWAY_CUSTOM) { $gatewayTypes = [GATEWAY_TYPE_CUSTOM]; } else { $accountGateway = $this->getAccountGateway($model->id); $paymentDriver = $accountGateway->paymentDriver(); $gatewayTypes = $paymentDriver->gatewayTypes(); $gatewayTypes = array_diff($gatewayTypes, array(GATEWAY_TYPE_TOKEN)); } $html = ''; foreach ($gatewayTypes as $gatewayTypeId) { $accountGatewaySettings = AccountGatewaySettings::scope()->where('account_gateway_settings.gateway_type_id', '=', $gatewayTypeId)->first(); $gatewayType = GatewayType::find($gatewayTypeId); if (count($gatewayTypes) > 1) { if ($html) { $html .= '
'; } $html .= $gatewayType->name . ' — '; } if ($accountGatewaySettings && $accountGatewaySettings->min_limit !== null && $accountGatewaySettings->max_limit !== null) { $html .= Utils::formatMoney($accountGatewaySettings->min_limit) . ' - ' . Utils::formatMoney($accountGatewaySettings->max_limit); } elseif ($accountGatewaySettings && $accountGatewaySettings->min_limit !== null) { $html .= trans('texts.min_limit', array('min' => Utils::formatMoney($accountGatewaySettings->min_limit)) ); } elseif ($accountGatewaySettings && $accountGatewaySettings->max_limit !== null) { $html .= trans('texts.max_limit', array('max' => Utils::formatMoney($accountGatewaySettings->max_limit)) ); } else { $html .= trans('texts.no_limit'); } } return $html; } ], ]; } public function actions() { $actions = [ [ uctrans('texts.resend_confirmation_email'), function ($model) { return $model->resendConfirmationUrl; }, function($model) { return !$model->deleted_at && $model->gateway_id == GATEWAY_WEPAY && !empty($model->resendConfirmationUrl); } ] , [ uctrans('texts.edit_gateway'), function ($model) { return URL::to("gateways/{$model->public_id}/edit"); }, function($model) { return !$model->deleted_at; } ], [ uctrans('texts.finish_setup'), function ($model) { return $model->setupUrl; }, function($model) { return !$model->deleted_at && $model->gateway_id == GATEWAY_WEPAY && !empty($model->setupUrl); } ], [ uctrans('texts.manage_account'), function ($model) { $accountGateway = $this->getAccountGateway($model->id); $endpoint = WEPAY_ENVIRONMENT == WEPAY_STAGE ? 'https://stage.wepay.com/' : 'https://www.wepay.com/'; return [ 'url' => $endpoint.'account/'.$accountGateway->getConfig()->accountId, 'attributes' => 'target="_blank"' ]; }, function($model) { return !$model->deleted_at && $model->gateway_id == GATEWAY_WEPAY; } ], [ uctrans('texts.terms_of_service'), function ($model) { return 'https://go.wepay.com/terms-of-service-us'; }, function($model) { return $model->gateway_id == GATEWAY_WEPAY; } ] ]; foreach (Cache::get('gatewayTypes') as $gatewayType) { $actions[] = [ trans('texts.set_limits', ['gateway_type' => $gatewayType->name]), function () use ($gatewayType) { $accountGatewaySettings = AccountGatewaySettings::scope() ->where('account_gateway_settings.gateway_type_id', '=', $gatewayType->id) ->first(); $min = $accountGatewaySettings && $accountGatewaySettings->min_limit !== null ? $accountGatewaySettings->min_limit : 'null'; $max = $accountGatewaySettings && $accountGatewaySettings->max_limit !== null ? $accountGatewaySettings->max_limit : 'null'; return "javascript:showLimitsModal('{$gatewayType->name}', {$gatewayType->id}, $min, $max)"; }, function ($model) use ($gatewayType) { // Only show this action if the given gateway supports this gateway type if ($model->gateway_id == GATEWAY_CUSTOM) { return $gatewayType->id == GATEWAY_TYPE_CUSTOM; } else { $accountGateway = $this->getAccountGateway($model->id); $paymentDriver = $accountGateway->paymentDriver(); $gatewayTypes = $paymentDriver->gatewayTypes(); return in_array($gatewayType->id, $gatewayTypes); } } ]; } return $actions; } private function getAccountGateway($id) { if (isset(static::$accountGateways[$id])) { return static::$accountGateways[$id]; } static::$accountGateways[$id] = AccountGateway::find($id); return static::$accountGateways[$id]; } }